【dog与lxy】8.25题解-necklace

necklace


题目描述

可怜的dog最终还是难逃厄运,被迫于lxy签下城下之约。这时候lxy开始刁难dog。
Lxy首先向dog炫耀起了自己的财富,他拿出了一段很长的项链。这个项链由n个珠子按顺序连在一起(1号珠子和n号珠子没有相连),每个珠子的颜色是1..m中的一种颜色(不妨用Ai表示第i个珠子的颜色)。
可dog当然不肯服气,于是他认为一定可以找到一段长度<=len的项链b1..blen(bi也是1..m中的一种颜色),没有出现过。
出现过的定义就是存在一组C1..Cm满足0<C1<C2<..<Cm<=n使得Aci=Bi。
然后lxy就要dog找出一段长度<=len的项链没有出现过。这时候dog发现自己中计了,因为项链太长了而lxy规定的len却很小。于是他又来找你求助了。不然的话,dog就要被迫签下卖国条约了……..现在就请你帮dog没有出现过的项链中最短的长度。

输入输出

输入文件:
第1行2个数n,m。接下来n行,每行一个数表示Ai。

输出文件:
一个数,没有出现过的项链中最短的长度。

样例

输入

2 3
1
2

输出

1

说明

样例解释
B1=3没有出现过,所以有长度为1,颜色为3的项链满足条件。

数据范围

100%的数据中,n<=500000,m<=100.
40%的数据中,n<=100,m<=3.
10%的数据中,n<=10,m<=2.

思路

给你一个长度为N的序列A1..An。其中Ai的取值范围[1,m]。要求一个最短长度Len,满足存在一个序列长度为Len的B1..Blen,这个序列在Ai中没有出现过。

  1. 我们思考假设在从最左端开始的一段区间范围内,如果存在1~m中间的所有数字,那么Len至少大于1。


  2. 假设紧跟这个区间之后又有一段数字包含了1~M。那么对于所有长度为2的序列就都已经存在,也就是Len要大于2。


  3. 以此类推,若整个Ai序列中以此有K个存在1~M的区间


  4. 而在k个1~M的区间之后,已经不会满足存在1 ~M中间的所有数字,那么Ans=K+1。

代码

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int n,m,ans;
int c[501000],h[500];
int main(){
    freopen("necklace.in ","r",stdin);
    freopen("necklace.out","w",stdout);
    scanf("%d%d",&n,&m);
    for(int i=1;i<=n;i++) scanf("%d",&c[i]); 
    int time=1,j=m;
    for(int i=1;i<=n;i++)
     if(h[c[i]]!=time){
         h[c[i]]=time; j--;
         if(j==0) {
            ans++;time++;j=m; 
          }
     } 
    printf("%d",ans+1);
        return 0;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1.把二元查找树转变成排序的双向链表 题目: 输入一棵二元查找树,将该二元查找树转换成一个排序的双向链表。 要求不...
    曲终人散Li阅读 8,650评论 0 19
  • 概述:排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    每天刷两次牙阅读 9,098评论 0 15
  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    蚁前阅读 10,603评论 0 52
  • 2017年9月12日 星期2 艰难 ❤️欣赏自己:很高兴迈出了第一步来到此次的开心大团队的首期特训营,我要通过我的...
    霞霞姐魔姝创始人阅读 1,477评论 0 0
  • 还记得你在家门前照的全家福吗 黑白的,邻居拍的,仅仅几张 还记得你嚷着‘不要’的样子吗 拉着母亲大红袄的袖口,手哆...
    倩何人换取阅读 1,351评论 2 1

友情链接更多精彩内容