标签:map
6 2 3 2 1 4 3 5 3 4
Case #1: 22
这题因为询问有1000次,所以转化为离线操作,先把所有的询问储存起来并找到询问区间长度的最大值,然后枚举寻找的区间起点,对于每个起点寻找是不是有连续k个数循环的区间。找到的判断条件:1.区间所有数都不同。2.区间的最大值减去最小值加1的值为区间的长度。可以用map判断是否出现相同的数,如果出现可以直接跳出循环,因为后面更大的区间长度肯定不满足。
#include<iostream> #include<stdio.h> #include<string.h> #include<math.h> #include<vector> #include<map> #include<queue> #include<stack> #include<string> #include<algorithm> using namespace std; int q[1006],a[100006],sum[1006]; int main() { int n,m,i,j,num1=0,min1,max1,maxx; while(scanf("%d%d",&n,&m)!=EOF) { for(i=1;i<=n;i++){ scanf("%d",&a[i]); } maxx=0; memset(sum,0,sizeof(sum)); //连续i个数的总区间个数 for(i=1;i<=m;i++){ scanf("%d",&q[i]); if(q[i]>maxx)maxx=q[i]; } for(i=1;i<=n;i++){ map<int,int>hash; hash.clear(); min1=max1=a[i]; for(j=1;j<=maxx && i+j-1<=n;j++){ if(hash[a[i+j-1]]==0){ hash[a[i+j-1]]++; if(min1>a[i+j-1])min1=a[i+j-1]; else if(max1<a[i+j-1])max1=a[i+j-1]; if(max1-min1+1==j)sum[j]++; } else break; } } num1++; printf("Case #%d:\n",num1); for(i=1;i<=m;i++){ printf("%d\n",sum[q[i]]); } } return 0; }
标签:map
原文地址:http://blog.csdn.net/kirito_acmer/article/details/46428373