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

2021-10-07 10:20:09 字數 1000 閱讀 2442

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

示例 1:

輸入: 「abcabcbb」

輸出: 3

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

示例 2:

輸入: 「bbbbb」

輸出: 1

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

示例 3:

輸入: 「pwwkew」

輸出: 3

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

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

通過次數532,563提交次數1,530,560

思路:

雙指標+map,使用兩個指標分別指向字串的左端和右端,根據不同情況對指標和map進行操作,具體思路如下:

1. 當此時的右指標所指向的值不存在於map之中的時候,表示當前從左到右的字串沒有重複,計算完當前長度之後更新max,之後將有指標指向的值在map之中做記錄,之後右指標向右遍歷;

2. 當此時的右指標所指向的值存在於map之中的時候,表示有重複的字元,計算此時的字串長度,減一之後更新max,之後對左指標進行更新,將左指標更新到在右指標之前的重複字元的下乙個位置,同時在更新的過程中將每個位置在map之中的記錄更新,最後將右指標指向下乙個位置,即可。

用自己的理解來說,就是使用乙個map記錄當前字串的所有字元,同時依據這個map來動態的維護乙個不包含重複字串的視窗的大小,最後記錄下視窗的最大值即可。

class

solution

else

right++

; left++;}

}return max;}}

;

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