3 無重複字元的最長子串

2021-08-28 19:00:35 字數 857 閱讀 6619

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

示例 1:

輸入: 「abcabcbb」

輸出: 3

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

示例 2:

輸入: 「bbbbb」

輸出: 1

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

示例 3:

輸入: 「pwwkew」

輸出: 3

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

請注意,答案必須是乙個子串,「pwke」 是乙個子串行 而不是子串。

方法:採用滑動視窗,遍歷一遍求解

/**

* 就是從頭開始產生乙個劃窗,沒遇到重複的窗體右邊界加1,統計窗體大小,

* 遇到重複的後,窗體的左邊界就移動到前面那個重複元素的下乙個

* 表示在兩個重複元素間最大子串已經知道了,應該開始從前面重複元素的下乙個字元開始了

*/public

static

intmaxnosubstring

(string s)

ans = math.

max(ans, j-i+1)

;//獲取新子串和就的最大子串的最長的長度

map.

put(key, j+1)

;//將新的元素記錄其位置的下乙個,或者用新的位置替換已有的元素

}return ans;

} ```

3 無重複字元的最長子串

給定乙個字串,找出不含有重複字元的最長子串的長度。示例 給定 abcabcbb 沒有重複字元的最長子串是 abc 那麼長度就是3。給定 bbbbb 最長的子串就是 b 長度是1。給定 pwwkew 最長子串是 wke 長度是3。請注意答案必須是乙個子串,pwke 是 子串行 而不是子串。思路 用 i...

3 無重複字元的最長子串

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

3 無重複字元的最長子串

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