給定乙個字串,請你找出其中不含有重複字元的 最長子串 的長度。
示例 1:
輸入: 「abcabcbb」
輸出: 3
解釋: 因為無重複字元的最長子串是 「abc」,所以其長度為 3。
示例 2:
輸入: 「bbbbb」
輸出: 1
解釋: 因為無重複字元的最長子串是 「b」,所以其長度為 1。
示例 3:
輸入: 「pwwkew」
輸出: 3
解釋: 因為無重複字元的最長子串是 「wke」,所以其長度為 3。
請注意,你的答案必須是 子串 的長度,「pwke」 是乙個子串行,不是子串。
思路:發現字串問題有些可以用slide window去解決
用到了預設字典
class solution:
def lengthoflongestsubstring(self, s):
""":type s: str
:rtype: int
"""freq = collections.defaultdict(int) #實際上這裡是開了乙個預設字典
l,r = 0,-1
res = 0
while l那麼為了之後 leetcode 裡面一些類似的題目,我們這裡做乙個 slide window 的模版,以後就可以重複使用了
class solution:
def lengthoflongestsubstring(self, s):
""":type s: str
:rtype: int
"""lookup = collections.defaultdict(int)
l, r, counter, res = 0, 0, 0, 0 # counter 為當前子串中 unique 字元的數量
while r < len(s):
lookup[s[r]] += 1
if lookup[s[r]] == 1: # 遇到了當前子串中未出現過的字元
counter += 1
r += 1
# counter < r - l 說明有重複字元出現,否則 counter 應該等於 r - l
while l < r and counter < r - l:
lookup[s[l]] -= 1
if lookup[s[l]] == 0: # 當前子串中的一種字元完全消失了
counter -= 1
l += 1
res = max(res, r - l) # 當前子串滿足條件了,更新最大長度
return res
leetcode 3 無重複的字串
給定乙個字串,請你找出其中不含有重複字元的 最長子串 的長度。示例 1 輸入 abcabcbb 輸出 3 解釋 因為無重複字元的最長子串是 abc 所以其長度為 3。示例 2 輸入 bbbbb 輸出 1 解釋 因為無重複字元的最長子串是 b 所以其長度為 1。示例 3 輸入 pwwkew 輸出 3 ...
leetcode 3 無重複字元的最長字元子串
堅持打卡!題目 給定乙個字串,請你找出其中不含有重複字元的 最長子串 的長度。示例 1 輸入 abcabcbb 輸出 3 解釋 因為無重複字元的最長子串是 abc 所以其長度為 3。示例 2 輸入 bbbbb 輸出 1 解釋 因為無重複字元的最長子串是 b 所以其長度為 1。示例 3 輸入 pwwk...
leetcode 3 最長無重複字串
3.longest substring without repeating characters 題面 given a string,find the length of the longest substring without repeating characters.給定字串,找到最長無重複字...