Leetcode 3 無重複字元的最長子串

2021-09-11 00:18:06 字數 1332 閱讀 1257

給定乙個字串,請你找出其中不含有重複字元的 最長子串 的長度。

示例 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.給定字串,找到最長無重複字...