问题描述
给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度。
示例 1:
输入: "abcabcbb"
输出: 3
解释: 因为无重复字符的最长子串是 "abc",所以其
长度为 3。
示例 2:
输入: "bbbbb"
输出: 1
解释: 因为无重复字符的最长子串是 "b"
,所以其长度为 1。
示例 3:
输入: "pwwkew" 输出: 3 解释: 因为无重复字符的最长子串是"wke"
,所以其长度为 3。 请注意,你的答案必须是 子串 的长度,"pwke"
是一个子序列,不是子串。
思路
首先拿到题目 最先想到的是遍历每个位置,统计每个位置开始非重复的字符串的长度,用两个for循环实现
class Solution(object):
def lengthOfLongestSubstring(self, s):
"""
:type s: str
:rtype: int
"""
result_max = 0
len_str = len(s)
for i in range(len_str):
dict_str = {}
for j in range(i, len_str):
str = s[j]
if str not in dict_str:
dict_str[str] = 1
result_max = max(len(dict_str), result_max)
else:
result_max = max(len(dict_str), result_max)
break
return result_max
提交到leetcode
由于这个算法的时间复杂度为O(n^2) ,对于一些复杂的字符串直接超时了,没有通过leetcode的审核
换种思路
如果没有重复的字符串只要返回这个字符串的长度就可以了,如果出现了重复的字符串,只要统计这个字符串后一位到现在的位置的字符串的长度就可以了,然后在刷新一下这个重复字符串的索引。
具体代码如下
class Solution:
def lengthOfLongestSubstring(self, s):
"""
:type s: str
:rtype: int
"""
max_len = 0
if s == None or s=="":
return max_len
start = 0
one_max = 0
dict_str = {}
len_str = len(s)
for i in range(len_str):
if s[i] in dict_str and dict_str[s[i]] >= start:
start = dict_str[s[i]] + 1
one_max = i - start + 1
dict_str[s[i]] = i
max_len = max(max_len, one_max)
return max_len
if __name__ == '__main__':
s = Solution()
print(s.lengthOfLongestSubstring("aaxxiododokdmnhdjjjjlnstyui"))