найти самую длинную подстроку с k различными / уникальными символами, используя хэш c ++

Другое событие NullPointerException возникает, когда объявляется массив объектов, а затем сразу же пытается разыменовать его внутри.

String[] phrases = new String[10];
String keyPhrase = "Bird";
for(String phrase : phrases) {
    System.out.println(phrase.equals(keyPhrase));
}

Этот конкретный NPE можно избежать, если порядок сравнения отменяется ; а именно, использовать .equals для гарантированного непустого объекта.

Все элементы внутри массива инициализируются их общим начальным значением ; для любого типа массива объектов, это означает, что все элементы null.

Вы должны инициализировать элементы в массиве перед доступом или разыменованием их.

String[] phrases = new String[] {"The bird", "A bird", "My bird", "Bird"};
String keyPhrase = "Bird";
for(String phrase : phrases) {
    System.out.println(phrase.equals(keyPhrase));
}

-1
задан Tin 14 April 2019 в 09:45
поделиться

1 ответ

Прежде maxSize = std::max(maxSize, i-start+1); необходимо удостовериться, что размер карты точно k - Вы никогда не можете достигать k, но текущий код instanly обновления maxSize.

Также помнят start значение в собственном max код

    if (map.size() == k) 
        if (i - start + 1 > maxSize) {
            maxSize = i - start + 1;
            astart = start;
        }
...
return {astart, maxSize};

проверка Ideone

0
ответ дан MBo 15 April 2019 в 00:53
поделиться
Другие вопросы по тегам:

Похожие вопросы: