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

2021-10-01 13:02:03 字數 1143 閱讀 5434

題目:

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

示例 1:

輸入: 「abcabcbb」

輸出: 3

解釋: 因為無重複字元的最長子串是 「abc」,所以其長度為 3。

示例 2:

輸入: 「bbbbb」

輸出: 1

解釋: 因為無重複字元的最長子串是 「b」,所以其長度為 1。

示例 3:

輸入: 「pwwkew」

輸出: 3

解釋: 因為無重複字元的最長子串是 「wke」,所以其長度為 3。

請注意,你的答案必須是 子串 的長度,「pwke」 是乙個子串行,不是子串。

分析:這題開始用的遍歷,導致沒有考慮開頭下標的問題,第二次遍歷就把第一次加入的結果給去掉了,導致結果錯誤下面總結leetcode powcai的想法,寫出的滑動視窗,**差不多。

演算法:滑動視窗

**:

在這裡插入**片class

solution

:def

lengthoflongestsubstring

(self, s:

str)

->

int:

index =

0 temp =

set(

) size =

0 max_size =

0for i in

range

(len

(s))

: size +=

1while s[i]

in temp:

temp.remove(s[index]

) index +=

1 size -=

1if size > max_size : max_size = size

temp.add(s[i]

)return max_size

滑動視窗可以看做乙個佇列,但不符合佇列的性質。例如"abcabcbb",逐個遍歷並儲存長度,當第二次遍歷a的時候不滿足條件,就把視窗內左邊的a給去掉,並更新index的值,若不更新,會導致重複讀入而無法刪除,最後輸出最大的長度即可。

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