Description
Given a string s
, find the length of the longest substring without repeating characters.
Example 1:
Input: s = "abcabcbb" Output: 3 Explanation: The answer is "abc", with the length of 3.
Example 2:
Input: s = "bbbbb" Output: 1 Explanation: The answer is "b", with the length of 1.
Example 3:
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.
Constraints:
0 <= s.length <= 5 * 104
s
consists of English letters, digits, symbols and spaces.
Solution
Python3
class Solution:
def lengthOfLongestSubstring(self, s: str) -> int:
N = len(s)
count = Counter()
res = 0
i = 0
for j, x in enumerate(s):
count[x] += 1
while count[x] > 1:
count[s[i]] -= 1
i += 1
res = max(res, j - i + 1)
return res
C++
class Solution {
public:
int lengthOfLongestSubstring(string s) {
int res = 0, N = s.size();
unordered_map<int, int> count;
for (int i = 0, j = 0; j < N; j++) {
count[s[j]]++;
while (count[s[j]] > 1) {
count[s[i]]--;
i++;
}
res = max(res, j - i + 1);
}
return res;
}
};