給定乙個字串,請你找出其中不含有重複字元的 最長子串 的長度。
示例 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.給定字串,找到最長無重複字...