题意

要你找一个最长的区间使得区间内每一个数出现次数都大于等于K。

题解-》https://blog.csdn.net/Ratina/article/details/97503663

#include<bits/stdc++.h>
using namespace std;
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
const int maxn=1e5+;
int N,C,K,a[maxn];
int mx[maxn<<],laz[maxn<<];
void pushdown(int rt){
if(laz[rt]==) return ;
mx[rt<<]+=laz[rt];
mx[rt<<|]+=laz[rt];
laz[rt<<]+=laz[rt];
laz[rt<<|]+=laz[rt];
laz[rt]=;
}
void update(int L,int R,int c,int l,int r,int rt)
{
if(L<=l&&r<=R)
{
laz[rt]+=c;
mx[rt]+=c;
return ;
}
pushdown(rt);
int m=(l+r)>>;
if(L<=m)
update(L,R,c,lson);
if(R>m)
update(L,R,c,rson);
mx[rt]=max(mx[rt<<],mx[rt<<|]);
}
int query(int rt, int l, int r){
if(l==r) return l;
pushdown(rt);
int mid=(l+r)>>;
if(mx[rt<<]==C) return query(rt<<,l,mid);
else if(mx[rt<<|]==C) return query(rt<<|,mid+,r);
else return -;
}
int main(){
while(~scanf("%d%d%d",&N,&C,&K)){
vector<int>pos[maxn];
for(int i=;i<=C;i++)
pos[i].push_back();
for(int i=;i<=N;i++)
{
scanf("%d",&a[i]);
pos[a[i]].push_back(i);
}
if(K==){
printf("%d\n",N);
continue;
}
memset(mx,,sizeof(mx));
memset(laz,,sizeof(laz));
int ans=,cur[maxn]={};
for(int i=;i<=N;i++){
int x=a[i];
int p=++cur[x];
update(i,i,C-,,N,);
if(pos[x][p-]+<=pos[x][p]-)
update(pos[x][p-]+,pos[x][p]-,-,,N,);
if(p>=K)
update(pos[x][p-K]+,pos[x][p-K+],,,N,);
int temp=query(,,N);
if(temp!=-)
ans=max(ans,i-temp+);
}
printf("%d\n",ans);
}
}

最新文章

  1. Linq语法详细
  2. Chart图表
  3. telnet输入乱码的解决
  4. iOS UIWebView重定向Cookie
  5. 备受SQL青睐的“1”
  6. Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境搭建教程
  7. linux 相关快捷键
  8. [AYUI]QQ管家源码已经开源
  9. 答辩ppt
  10. fw:sed的高级用法
  11. linux 下安装 搭建 svn服务器
  12. HMMPfam的安装使用手记(转载)
  13. c# 無彈窗调用打印机
  14. ActivityLifeCycle官方demo分解
  15. 集线器(HUB),交换机,和路由器的区别
  16. Word字体与像素的对应关系(转)
  17. 201521123003《Java程序设计》第8周学习总结
  18. Linux替换命令
  19. 引导加载程序之争: LILO 和 GRUB
  20. TeamCity安装

热门文章

  1. SVN的各种符号含义,svn的星号,感叹号,问号等含义
  2. ls 命令通配符(3)
  3. Cyclic Nacklace HDU 3746 KMP 循环节
  4. shell学习笔记3---shell变量
  5. linux-导入python自定义模块的使用方法
  6. 分布式均匀算法--hash性一致算法--hash slot(转)
  7. HTML文本格式化标签(Formatting)
  8. R语言multiplot函数绘制多张图像
  9. 18.Linux-CentOS系统根目录空间使用率100%问题?
  10. Zabbix--05 Grafana、percona、自动发现和自动注册