题目:给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。
示例 1:
输入: s ="abcabcbb"
输出: 3
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。
示例 2:
输入: s = "pwwkew"
输出: 3
解释: 因为无重复字符的最长子串是 "wke",所以其长度为 3。
答案必须是 子串 的长度,"pwke" 是一个子序列,不是子串。
提示:s 由英文字母、数字、符号和空格组成
解题思路:
在字符串中,字典的key作为值,字典的value作为值对应的索引。
通过取出的值跟最开始计数的值进行比较,找出最大值。
解题逻辑步骤:
1.定义一个函数,传一个参。
2.判断传入的字符串是否为空。
3.定义一个空字典
4.每次循环中最长的子串长度
5.重复在的位置+1
6.遍历字符中的每一个字节,判断当前遍历的字符是否在字典里,和当前字符的下标是否大于或等于重复字符的位置。
6(1).记录当前字符的+1
6(2).在循环中,最大不重复的子串长度
6(3).把当前位置覆盖字典的位置
7.比较这次循环中的最大不重复子串长度和循环最大不重复子串长度
代码如下:
# 无重复字符的最长子串
def lengthOfLongestSubstring(s):
"""
:type s: str #字符串
:rtype: int #整数
"""
# 存循环中最长的子串长度
max_len = 0
# 判断传入的字符串是否为空
if s is None or len(s) == 0:
return max_len
# 定义一个字典,存不重复的字符和字符所在的下标
str_dict = {}
# 存每次循环中最长的子串长度
one_max = 0
# 记录最近重复字符所在的位置+1
start = 0
# 遍历字符中的每一个字符
for i in range(len(s)):
# 判断当前字符是否在字典中和当前字符的下标是否大于等于最近重复字符的所在位置
if s[i] in str_dict and str_dict[s[i]] >= start:
# 记录当前字符的值+1
start = str_dict[s[i]] + 1
# print start
# 在此次循环中,最大的不重复子串的长度
one_max = i - start + 1
# 把当前位置覆盖字典中的位置
str_dict[s[i]] = i
# 比较此次循环的最大不重复子串长度和历史循环最大不重复子串长度
max_len = max(max_len, one_max)
return max_len
print(lengthOfLongestSubstring('pwwssffasdf'))
结果如下:
4