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

2021-09-07 04:53:09 字數 1072 閱讀 7827

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

示例 1:

輸入: 「abcabcbb」

輸出: 3

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

示例 2:

輸入: 「bbbbb」

輸出: 1

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

示例 3:

輸入: 「pwwkew」

輸出: 3

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

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

對於字串: 「pwwkew」。

子串需要字元連續的,如其中的pww,wwk。

子串行不需要連續,如 pwk,pke等

用一層迴圈提取每個字元,單獨建立乙個不重複的子串,每提取乙個字元,在子串中進行檢測是否重複,當有重複字元時,則更新該子串,更新的同時需要不斷檢測是否為較長的子串。

class solution:

def lengthoflongestsubstring(self, s):

""":type s: str

:rtype: int

"""temp = res = "" #temp暫存子串,res暫存合適的子串

for item in s:#對於字串s中的每個字元

if item not in temp:#如果這個字元不在temp當中

temp += item

if len(temp) > len(res):

res = temp

else:

i = temp.index(item)#找到索引

if i == len(temp)-1:

temp = item#如果到達末尾

else:

temp = temp[i+1:] + item#沒達到末尾

if len(temp) > len(res):

res = temp

return len(res)

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