演算法 水位 無重複字元的最長子序列

2021-10-05 23:27:10 字數 1303 閱讀 4703

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

示例 1:

輸入: 「abcabcbb」

輸出: 3

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

示例 2:

輸入: 「bbbbb」

輸出: 1

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

示例 3:

輸入: 「pwwkew」

輸出: 3

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

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

思路是關注最近的兩個相同字元間距離,同時增加水位限制,水位始終為0或相同字元較舊那個位置的下乙個位置。

水位指向當前首個不重複數字位置,用來限制計算重複元素的最小位置,不能低於水位去找重複元素來計算路徑長度,因為水位所在的位置之前已經有其他重複元素了。

比如abca,初始為0,直到第二個a時水位更新為前乙個a的下乙個位置即1

再比如 kacbak

第一次遇到重複元素a時,將水位置為 1 + 1 = 2

第二次,又遇到重複元素k,此時因為上次重複的k的位置0在數字2之下,表示舊k位置和水位之間有其他重複元素,這裡就是a

所以不能直接以 第二個k的位置 5 - 第乙個k的位置的下乙個位置 1 + 1 這樣計算長度,因為存在重複元素a!

同時本演算法用128位的int陣列代替了hashmap,速度再次提高

取128的原因是ascii碼一共128個。也可以設為256,因為char為8bit,即針最多2^8-1 個字元

無重複字元最長子串

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

無重複字元最長子串

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

演算法題 無重複字元的最長子串

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