Назад к вопросам
МВидео
Middle+
4
// Дана строка s. Нужно найти длину самой длинной подстроки без повторяющихся символов. // Примеры: // s = "abcabcbb", ответ: 3 ("abc") // s = "cccccccc", ответ: 1 ("c") // s = "pwwkew", ответ: 3 ("wke") // s = "", ответ: 1 = 0 // Строка s состоит из английских букв, цифр, символов и пробелов func lengthOfLongestSubstring(s string) int { return 0 }
Компании, где спрашивали
Ответ от нейросети
sobes.tech AI
Для поиска длины самой длинной подстроки без повторяющихся символов можно использовать алгоритм "скользящего окна" с двумя указателями и хеш-таблицей для отслеживания последних позиций символов.
Пример решения на Go:
def lengthOfLongestSubstring(s string) int {
lastIndex := make(map[rune]int)
maxLen := 0
start := 0
for i, ch := range s {
if pos, found := lastIndex[ch]; found && pos >= start {
start = pos + 1
}
lastIndex[ch] = i
if currentLen := i - start + 1; currentLen > maxLen {
maxLen = currentLen
}
}
return maxLen
}
Объяснение:
lastIndexхранит последний индекс каждого символа.start— начало текущего окна без повторов.- При встрече повторяющегося символа с индексом >= start сдвигаем start.
- Обновляем максимальную длину окна.
Так алгоритм работает за O(n), где n — длина строки.