CSES-1141 Playlist

题目传送门https://vjudge.net/problem/CSES-1141

解题思路

遍历一下......

对于每一个 ,设 为以 为结尾的合法序列长度。

首先,在没有任何特殊情况下,易得

如果 之前出现过,那么这个连续序列里就有可能会有重复的数(所以就要判一下)。

上一次出现的位置。

,即在这个序列里,我们需要切掉前面重复之前的一截。

同时,动态更新 的位置,ans 取最大值。

代码

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;

int n,a[200001];
int len[200001];
map<int,int> flag;
int main()
{
	ios::sync_with_stdio(0);
	cin.tie(0);
	cout.tie(0);
	
	cin>>n;
	for(int i=1;i<=n;i++)
	{
		cin>>a[i];
	}
	int ans=0,last;
	for(int i=1;i<=n;i++)
	{
		len[i]=len[i-1]+1;
		if(flag[a[i]])
		{
			last=flag[a[i]];
			if(last>=i-len[i]+1)
				len[i]-=(last-(i-len[i]+1)+1);
		}
		flag[a[i]]=i;
		ans=max(ans,len[i]);
	}
//	for(int i=1;i<=n;i++)
//	{
//		cout<<len[i]<<" ";
//	}
	cout<<ans;
	return 0;
}
相关推荐
NiceCloud喜云4 小时前
Opus 4.8 的 Effort Control 怎么选:Low 到 Max 五档策略
android·java·大数据·前端·c++·python·spring
小羊在睡觉4 小时前
力扣84. 柱状图中最大的矩形
后端·算法·leetcode·golang·go
cjhbachelor4 小时前
c++继承
c++
3DVisionary4 小时前
蓝光三维扫描:医疗制造的精度焦虑怎么解
人工智能·算法·制造·蓝光三维扫描·医疗制造·三维检测·义齿检测
好评笔记4 小时前
机器学习面试八股——常用损失函数
人工智能·深度学习·算法·机器学习·校招
weixin_468466854 小时前
全局与局部注意力机制新手实战指南
人工智能·python·深度学习·算法·自然语言处理·transformer·注意力机制
肩上风骋5 小时前
C++14特性
开发语言·c++·c++14特性
_日拱一卒5 小时前
LeetCode:994腐烂的橘子
java·数据结构·算法·leetcode·深度优先
珂朵莉MM5 小时前
第七届全球校园人工智能算法精英大赛-算法巅峰赛产业命题赛第3赛季优化题--束搜索
人工智能·算法
Omics Pro6 小时前
首个!外源天然产物综合性代谢图谱
数据库·人工智能·算法·机器学习·r语言