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

2021-10-01 23:12:50 字數 1020 閱讀 5121

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

示例 1:

輸入: 「abcabcbb」

輸出: 3

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

示例 2:

輸入: 「bbbbb」

輸出: 1

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

示例 3:

輸入: 「pwwkew」

輸出: 3

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

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

思路一:dp[i]表示以i開始的最長不包含重複的str[i]的字串,然後對於每一位j(i>j>=dp[i])判斷dp[j]的位置確定最長不重複字串的位置。

這個辦法速度較慢,差不多是o(n*n)的複雜度

class

solution

}for

(int i=

0;i)return ans;

}}

思路二:雙端佇列,維護當前最長字串的起始位置,用cnt統計字母個數,用陣列模擬雙端佇列

class

solution

else

cnt[queue[

(front+1)

%(l+1)

]]--;

front =

(front+1)

%(l+1)

;}cnt[s.

charat

(i)]++;

queue[

++rear]

= s.

charat

(i);

} ans = math.

max(ans,

(rear-front+l+1)

%(l+1)

);}return ans;

}}

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