Description
小度熊拿到了一个无序的数组,对于这个数组,小度熊想知道是否能找到一个k 的区间,里面的 k 个数字排完序后是连续的。
现在小度熊增加题目难度,他不想知道是否有这样的 k 的区间,而是想知道有几个这样的 k 的区间。
现在小度熊增加题目难度,他不想知道是否有这样的 k 的区间,而是想知道有几个这样的 k 的区间。
Input
输入包含一组测试数据。
第一行包含两个整数n,m,n代表数组中有多少个数字,m 代表针对于此数组的询问次数,n不会超过10的4次方,m 不会超过1000。第二行包含n个正整数,第 I 个数字代表无序数组的第 I 位上的数字,数字大小不会超过2的31次方。接下来 m 行,每行一个正整数 k,含义详见题目描述,k 的大小不会超过1000。
第一行包含两个整数n,m,n代表数组中有多少个数字,m 代表针对于此数组的询问次数,n不会超过10的4次方,m 不会超过1000。第二行包含n个正整数,第 I 个数字代表无序数组的第 I 位上的数字,数字大小不会超过2的31次方。接下来 m 行,每行一个正整数 k,含义详见题目描述,k 的大小不会超过1000。
Output
第一行输"Case #i:"。(由于只有一组样例,只输出”Case #1:”即可)
然后对于每个询问的 k,输出一行包含一个整数,代表数组中满足条件的 k 的大小的区间的数量。
然后对于每个询问的 k,输出一行包含一个整数,代表数组中满足条件的 k 的大小的区间的数量。
Sample Input
6 2 3 2 1 4 3 5 3 4
Sample Output
Case #1: 2 2
#include<stdio.h> #include<cstring> #include<algorithm> using namespace std; int a[10000],ans[1001],ex[10001]; int main() { int n,m,k,index; scanf("%d%d",&n,&m); for(int i=1;i<=n;i++) scanf("%d",&a[i]); printf("Case #1:\n"); memset(ans,0,sizeof(ans)); for(int i=1;i<=n;i++) { memset(ex,0,sizeof(ex)); ex[a[i]]=1; int Max=a[i],Min=a[i]; for(int j=i+1;j<=n;j++) { if(ex[a[j]]++) break; Max=max(Max,a[j]); Min=min(Min,a[j]); if(Max-Min==j-i) ans[j-i+1]++; } } ans[1]=n; for(int i=0;i<m;i++) { scanf("%d",&k); printf("%d\n",ans[k]); } return 0; }
好讨厌,又超时。。。
#include<cstdio> #include<algorithm> using namespace std; int a[10100],s; int main() { int n,m;int k=1,num; scanf("%d%d",&n,&m); for(int i=1;i<=n;i++) scanf("%d",&a[i]); printf("Case #%d:\n",k++); while(m--) { num=0; scanf("%d",&s); int minm,maxm; for(int i=1;i<=n-s+1;i++) { maxm=a[i];minm=a[i]; for(int j=i;j<=i+s-1;j++) { maxm=max(maxm,a[j]); minm=min(minm,a[j]); } //printf("%d %d ",maxm,minm); if(maxm-minm+1==s) num++; } printf("%d\n",num); } return 0; }