题解 | #最长无重复子数组#

最长无重复子数组

http://www.nowcoder.com/practice/b56799ebfd684fb394bd315e89324fb4

双指针:可视为一个从左到右移动的滑动窗口

class Solution:
    def maxLength(self , arr ):
        # write code here
        usedChar={} #记录当前不重复子数组
        l=0 #数组左边
        res=0 #最终输出,即最长无重复子数组的长度
        for i in range(len(arr)):
            if arr[i] in usedChar and usedChar[arr[i]]>=l: #这个已经出现
                l=usedChar[arr[i]]+1 #跳过这个,从下一个重新记录
            else:
                res=max(res, i-l+1)  #没有重复,就一边增加窗口宽度一边调整最大值
            usedChar[arr[i]]=i #匹配键值对
        return res
全部评论

相关推荐

10-11 17:45
门头沟学院 Java
走吗:别怕 我以前也是这么认为 虽然一面就挂 但是颇有收获!
点赞 评论 收藏
分享
11-09 11:01
济南大学 Java
Java抽象带篮子:外卖项目真得美化一下,可以看看我的详细的外卖话术帖子
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务