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

最长无重复子数组

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-07 13:31
怀化学院 Java
勇敢牛牛不怕难:又疯一个
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务