10057 - A mid-summer night's dream
10057 - A mid-summer night's dream.
描述:先对数组排序,第一个数是找出中间数,第二个数是找出与此相同的数有多少,第三个数是两个数的区间内有多少数 #include <cstdio> #include <cstdlib> int cmp(const void *p1,const void *p2) { return *(int*)p1 - *(int*)p2; } int num[1000010]; int main() { //freopen("a.txt","r",stdin); int n; while(scanf("%d",&n)!=EOF) { for(int i=0; i<n; i++) scanf("%d",&num[i]); qsort(num,n,sizeof(int),cmp); int k=0; int a=1,b; if(n%2==0) { k=num[n/2-1]; b=num[n/2]-k+1; } else { k=num[n/2]; b=1; } if(n%2==1) { for(int i=n/2+1; i<n; i++) if(num[i]==k) a++; else break; for(int i=n/2-1; i>=0; i--) if(num[i]==k) a++; else break; } else { for(int i=n/2; i<n; i++) if(num[i]==num[n/2]) a++; else break; for(int i=n/2-2; i>=0; i--) if(num[i]==k) a++; else break; } printf("%d %d %d\n",k,a,b); } return 0; }