題目描述:給定乙個字串,請你找出其中不含有重複字元的最長子串的長度。
示例1:
輸入: 「abcabcbb」示例2:輸出: 3
解釋: 因為無重複字元的最長子串是 「abc」,所以其長度為 3。
輸入: 「bbbbb」示例3:輸出: 1
解釋: 因為無重複字元的最長子串是 「b」,所以其長度為 1。
輸入: 「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.給定字串,找到最長無重複字...