2021-01-10 Python百日打卡学习自【夸可编程】

题目

输入一个字符串,返回该串中最长不含重复字符的子串长度
例子

'abcabcbb' -> 3
'bbbbbb' -> 1

假设

输入的字符串一定不为None或空串
输入的字符串中的字符仅为小写英文字母
tips

网站解法
解法2:
def lengthOfLongestSubstring(s):
# 哈希集合,记录每个字符是否出现过
occ = set()
n = len(s)
# 右指针,初始值为 -1,相当于我们在字符串的左边界的左侧,还没有开始移动
rk, ans = -1, 0
for i in range(n):
if i != 0:
# 左指针向右移动一格,移除一个字符
occ.remove(s[i - 1])
while rk + 1 < n and s[rk + 1] not in occ:
# 不断地移动右指针
occ.add(s[rk + 1])
rk += 1
# 第 i 到 rk 个字符是一个极长的无重复字符子串
ans = max(ans, rk - i + 1)
return ans
性能
时间复杂度O(n)
空间复杂度O(n)
双指针思路


def lengthOfLongestSubstring(s):
    occ = set()
     n = len(s)
     rk, ans = 0, 0
     for i in range(n):
# 每次循环把当前的元素删除,然后再去检查是否有最大子串
            if i != 0:
                  occ.remove(s[i-1])
# occ 中是i到rk的最大子串 , 当rk指向元素在set中,那么就停止循环了,让occ不断remove,直到当前rk可以入set
             while rk < n and s[rk] not in occ: 
                   occ.add(s[rk])
                    rk += 1
              ans = max(ans, rk -i)
        return rk
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容