Leetcode 3. Longest Substring Without Repeating Characters

https://leetcode.com/problems/longest-substring-without-repeating-characters/html

Given a string, find the length of the longest substring without repeating characters.python

Example 1:算法

Input: "abcabcbb"
Output: 3 Explanation: The answer is , with the length of 3. "abc"

Example 2:app

Input: "bbbbb"
Output: 1 Explanation: The answer is , with the length of 1. "b"

Example 3:ide

Input: "pwwkew"
Output: 3 Explanation: The answer is , with the length of 3. Note that the answer must be a substring,  is a subsequence and not a substring."wke""pwke"

  • 字符串簡單題。Sliding window + set / dict
  • 基礎算法是把把char都放到一個set裏,left指針按照步長爲1往右移動並判重。
  • 優化算法是出現重複時,直接把window右移到不重複位置再繼續,即left指針移動到重複位置+1。
    • https://leetcode.com/problems/longest-substring-without-repeating-characters/solution/
    • The above solution requires at most 2n steps. In fact, it could be optimized to require only n steps. Instead of using a set to tell if a character exists or not, we could define a mapping of the characters to its index. Then we can skip the characters immediately when we found a repeated character.
    • The reason is that if s[j] have a duplicate in the range [i, j) with index j', we don't need to increase i little by little. We can skip all the elements in the range [i, j'] and let i to be j' + 1 directly.
  • Python3 字典 | 菜鳥教程
    • http://www.runoob.com/python3/python3-dictionary.html
  • Python3 集合 | 菜鳥教程
    • http://www.runoob.com/python3/python3-set.html
 1 class Solution:
 2     def lengthOfLongestSubstring(self, s: str) -> int:
 3         d = dict()  # current index of character        
 4         left, right, maxlen = 0, 0, 0
 5         n = len(s)
 6         
 7         while right < n:
 8             # if char in dict[j'],skip all the elements in the range [i,j'] and let i to be j'+1 directly.
 9             if s[ right ] in d:
10                 left = max( d[ s[ right ] ], left ) 
11 
12             maxlen = max( right - left + 1, maxlen )
13 
14             # set next available index for left, i.e. j'+1
15             d[ s[ right ] ] = right + 1
16 
17             right += 1
18                 
19         return maxlen
20     
21     def lengthOfLongestSubstring1(self, s: str) -> int:
22         dict = set()
23         
24         n = len(s)
25         left, right, maxlen = 0, 0, 0
26         
27         while right < n:
28             if s[ right ] not in dict:
29                 dict.add( s[ right ] )
30                 maxlen = max( maxlen, right - left + 1 )
31                 right += 1
32             else:
33                 dict.remove( s[ left ] )
34                 left += 1                
35                 
36         return maxlen
View Code
相關文章
相關標籤/搜索