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

最长无重复子数组

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

代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可

@param arr int整型一维数组 the array

@return int整型

from collections import deque class Solution: def maxLength(self , arr: List[int]) -> int: # write code here d = deque() res =[] if len(arr) < 2: return len(arr) for i in arr: if i in d:
for j in range(len(d)): if d[0] != i: d.popleft() else: d.popleft() break d.append(i) res.append(len(d)) #print(d) return max(res)

核心思路:如果遇到重复的数字就从左边开始pop,直到把重复的数字pop出去,再重新append,保证放在队列里的数不重复

全部评论

相关推荐

11-18 15:57
门头沟学院 Java
最终归宿是测开:这个重邮的大佬在重邮很有名的,他就喜欢打92的脸,越有人质疑他,他越觉得爽😂
点赞 评论 收藏
分享
10-09 09:39
门头沟学院 C++
HHHHaos:这也太虚了,工资就一半是真的
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务