leetcode之無重複字元的最長子串

2021-10-03 09:46:54 字數 1941 閱讀 2946

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

示例 1:

輸入: 「abcabcbb」

輸出: 3

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

示例 2:

輸入: 「bbbbb」

輸出: 1

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

示例 3:

輸入: 「pwwkew」

輸出: 3

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

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

滑動視窗思維。

假想乙個視窗,這個視窗可以擴大,也可以縮小。只要加入字元,刪除字元,就可以改變視窗大小。

視窗從字串的左邊,滑行到右邊,可能會加入一些字元,也可能把裡面的字元吐出來。

視窗裡存放的字元不允許重複,這樣就能解決所提問題,那麼怎麼實現?

class

solution

:def

lengthoflongestsubstring

(self, s:

str)

->

int:

que =

curlen =

0 ans =

0for i in s:

while i in que:

que.pop(0)

ans =

max(ans,

len(que)

)return ans

時間太長了,那麼將我們使用乙個引用指向佇列的首元素,不需申明空間,直接指向字串某個字元上就行。畢竟總是連續的

那麼用乙個集合存放隊中的元素。(當然,也可以直接把佇列做在字串上,只需要加上head,tail兩個引用,同時s[head:tail]表示佇列,不過佇列操作終究比較慢)。

很快,也很神奇地就用字典加乙個頭引用就設計出了乙個佇列。字典很快,比列表的操作快多了,但有點複雜56 ms/13.6mb:

class

solution

:def

lengthoflongestsubstring

(self, s:

str)

->

int:

lookup =

set(

) curlen, maxlen =0,

0 left =

0for i in s:

curlen +=

1while i in lookup:

lookup.remove(s[left]

) curlen -=

1 left +=

1if maxlen < curlen:

maxlen = curlen

lookup.add(i)

return maxlen

c++**4ms/9.2mb

#include 

class

solution

} tail +=1;

tmp = tail - head;

if(tmp>ans) ans = tmp;

if(tail>=slen)

break;}

return ans;}}

;

LeetCode之無重複字元的最長子串

題目描述 給定乙個字串,請你找出其中不含有重複字元的 最長子串 的長度。輸入 abcabcbb 輸出 3 解釋 因為無重複字元的最長子串是 abc 所以其長度為 3。思路 判斷每乙個區間是否有重複的字元,如果沒有就更新它。以下為 class solution return ans public bo...

LeetCode題庫練習之無重複字元的最長子串

參考自 題目描述 給定乙個字串,請你找出其中不含有重複字元的 最長子串 的長度。解題思路 運用滑動視窗的思想,從字串第乙個位置開始遍歷,當出現重複字元時,移除最左邊的字元。直至沒有重複的字元時停止。class solution lookup.insert s i maxstr max maxstr,...

leetcode題解之無重複字元的最長子串

給定乙個字串,請你找出其中不含有重複字元的 最長子串的長度。示例 1 輸入 abcabcbb 輸出 3 解釋 因為無重複字元的最長子串是 abc 所以其長度為 3。示例 2 輸入 bbbbb 輸出 1 解釋 因為無重複字元的最長子串是 b 所以其長度為 1。示例 3 輸入 pwwkew 輸出 3 解...