3 無重複字串的最長子串

2021-09-19 01:25:46 字數 1025 閱讀 2579

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

示例 1:

輸入: 「abcabcbb」

輸出: 3

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

示例 2:

輸入: 「bbbbb」

輸出: 1

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

示例 3:

輸入: 「pwwkew」

輸出: 3

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

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

class

solution

:def

lengthoflongestsubstring

(self, s:

str)

->

int:

n =len(s)

max=

0# 子串的起始位置

start =

0# 字典 key是字元 value是該字元最大的索引

d =# 遍歷字串 i表示當前子串的最後乙個位置

for i in

range

(n):

# 若 當前遍歷到的字元先前已經遇到 且 當前子串的起始位置 <= 先前該字元的索引(start不能往回走)

if s[i]

in d and start <= d[s[i]]:

# 上述條件滿足 更新當前子串的起始位置

start = d[s[i]]+

1# length 是當前子串的長度

length = i - start +

1if length >

max:

max= length

# 存入新字元 value是索引 或 更新舊字元 value是新索引

d[s[i]

]= i

return

max

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

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

無重複字串的最長子串

題目描述 給定乙個字串,找出不含有重複字元的最長子串的長度。示例 給定 abcabcbb 沒有重複字元的最長子串是 abc 那麼長度就是3。給定 bbbbb 最長的子串就是 b 長度是1。給定 pwwkew 最長子串是 wke 長度是3。解題思路 在解題之前我們先要知道如何輸入乙個字串,又不會浪費空...

3 無重複字元的最長子串

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