力扣第3題無重複字元的最長子串

2021-10-04 21:46:51 字數 874 閱讀 7944

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

例項1:

輸入: 「abcabcbb」

輸出: 3

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

示例 2:

輸入: 「bbbbb」

輸出: 1

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

示例 3:

輸入: 「pwwkew」

輸出: 3

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

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

思路:採用滑動視窗思想,遍歷字串,如果存在,且在視窗的內部,就移動,如果存在但是不在視窗的左邊,就不用移動.

可以使用left=math.max(視窗的左邊,存在的元素的位置)取他們的較大值,來移動.

然後不管是否存在都新增到map中,更新視窗的長度,不存在新增,視窗的長度肯定增加,如果存在,就需要移動或者不動視窗,視窗的長度取max=math.max(max,i-left+1)

如果是左端移動了,就保持max不變,如果新增了元素,就用右端減去左端加1,就是視窗的長度

public

class

solution

//將元素新增到視窗中

map.

put(s.

charat

(i),i)

;//更新長度

max=math.

max(max,i-left+1)

;}return max;

}}

力扣3 無重複字元的最長子串

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

力扣 3 無重複字元的最長子串

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

力扣 程式設計題3 無重複字元的最長子串

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