
Powered by:NEFU AB-IN
link
文章目录799.最长连续不重复子序列
题意思路代码
799.最长连续不重复子序列题意
思路给定一个长度为 n 的整数序列,请找出最长的不包含重复的数的连续区间,输出它的长度。
模板
j = 0
for i in range(n):
while j < i and check(j, i):
j += 1
...
...
维护两个指针,左指针j,右指针i,保证两个指针都是单调的
i: 指定区间的右边界
j: 指定区间的左边界
它的含义为: 当i固定时j往左最远能到什么地方
此题的逻辑为,当i往右移时,新进区间的值,如果被标记了,就说明区间里有这个值,那么就把j往右移即可,直到那个值被d出去
代码'''
Author: NEFU AB-IN
Date: 2022-01-25 17:28:23
FilePath: ACMAcwing799.py
LastEditTime: 2022-01-25 17:39:28
'''
from collections import Counter
d = Counter()
if __name__ == "__main__":
n = int(input())
lst = list(map(int, input().split()))
j = 0
res = 0
for i in range(n):
d[lst[i]] += 1
while j < i and d[lst[i]] == 2:
d[lst[j]] -= 1
j += 1
res = max(res, i - j + 1)
print(res)
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)