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

2021-09-29 18:11:43 字數 1413 閱讀 2311

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

示例1

輸入: 「abcabcbb」

輸出: 3

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

示例2

輸入: 「bbbbb」

輸出: 1

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

示例3

輸入: 「pwwkew」

輸出: 3

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

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

解題思路

暴力破解法。逐個遍歷每個字串,從頭開始遍歷字串,以當前字元和後面的字元組成的字串進行判斷,選取出滿足條件的最長的子字串,即是最終的結果。這個是比較簡單的,但是,還有但是,放在leetcode中時跑不出來的,因為這個消耗的時間太長了,出現了lte,時間複雜度是o(n3),小夥伴們如果誰把這個演算法優化成o(n2),記得issue我!

滑動視窗。這個就是使用計算機網路中的概念了,叫做滑動視窗(sliding window),視窗的大小是可以收縮和擴張的,視窗也是可以移動的,視窗裡[i, j]放的是不重複的子字串,如果出現了重複的字串,就讓視窗左側向右側收縮一下(i + 1),如果當前遍歷的字元不在視窗裡,則將這個字元加入到視窗裡(j++),找到視窗中字串長度最大的即可。

滑動視窗的優化。第二種解法使用的是滑動視窗,第三種解法就是優化了一下滑動視窗,滑動視窗中遇到了相同的字串,每次只會讓視窗向右收縮一下,但是收縮了一下此是重複的字元還是在視窗中,然後接著收縮,直到將重複的字元剔除掉,我們針對這個進行優化,遇到重複字元不是收縮了一下,而是在視窗中找到這個字元,將視窗的左側直接跳到這個重複字元的下乙個,免去了單個收縮的時間。大大提高了效率。

**在本人的github中

個人部落格位址

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