April 13, 2023
3. Longest Substring Without Repeating Characters
Given a string s, find the length of the longest substring without repeating characters.
Input: s = "abcabcbb" Output: 3 Explanation: The answer is "abc", with the length of 3.
Input: s = "bbbbb" Output: 1 Explanation: The answer is "b", with the length of 1.
Input: s = "pwwkew" Output: 3 Explanation: The answer is "wke", with the length of 3. Notice that the answer must be a substring, "pwke" is a subsequence and not a substring.
Solution
def longestPalindrome(s: str) -> str:
start_index = 0
chars_map = {}
max_length = 1
for i in range(len(s)):
char = s[i]
used_char_index = chars_map.get(char, -1)
if used_char_index >= start_index:
start_index = used_char_index + 1
chars_map[char] = i
max_length = max(max_length, (i + 1) - start_index)
return max_length
print(longestPalindrome("babad")) # Output: 2
print(longestPalindrome("abcabcbb")) # Output: 3
print(longestPalindrome("bbbbb")) # Output: 1
print(longestPalindrome(" ")) # Output: 1
print(longestPalindrome("")) # Output: 0
print(longestPalindrome("au")) # Output: 2