题目:无重复字符的最长子串。html
给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度。python
示例 1:code
输入: “abcabcbb”
输出: 3
解释: 由于无重复字符的最长子串是 “abc”,因此其长度为 3。
示例 2:htm
输入: “bbbbb”
输出: 1
解释: 由于无重复字符的最长子串是 “b”,因此其长度为 1。
示例 3:blog
输入: “pwwkew”
输出: 3
解释: 由于无重复字符的最长子串是 “wke”,因此其长度为 3。ci
请注意,你的答案必须是 子串 的长度,“pwke” 是一个子序列,不是子串。字符串
解法1:常规思路get
class Count: def __init__(self): self.curLength = 0 def compare(self, temp: str): lens = len(set(temp)) if lens != len(temp): return False else: self.curLength = lens return True def circulation(self, s: str): flag = False length_s = len(s) # 8 temp = "" j = 0 while j + self.curLength < length_s: # 1+0<8 temp = s[j:j + self.curLength + 1] # temp = "a" if self.compare(temp): # tem不重复 continue else: j += 1 return self.curLength
解法2:神仙思路(网上看的)string
class Solution: def lengthOfLongestSubstring(self, s): """ :type s: str :rtype: int """ st = {} i, ans = 0, 0 for j in range(len(s)): if s[j] in st: i = max(st[s[j]], i) ans = max(ans, j - i + 1) st[s[j]] = j + 1 return ans