c语言问题: 输入格式 输入有多组数据。 每组数据两行。 第一行包含一个正整数n(小于等于1000
c语言问题:输入格式输入有多组数据。每组数据两行。第一行包含一个正整数n(小于等于10000),代表会员人数。第二行包含n个正整数(小于等于10000),代表各会员AC的...
c语言问题:
输入格式
输入有多组数据。
每组数据两行。
第一行包含一个正整数n(小于等于10000),代表会员人数。
第二行包含n个正整数(小于等于10000),代表各会员AC的题数。
输出
对应每组数据,如果超过一半的会员AC的题数相同,则输出这个题数,否则输出0。
样例输入
7
14 36 14 14 14 3 8
10
56 56 56 56 3 35 35 8 77 56
样例输出
14
0 展开
输入格式
输入有多组数据。
每组数据两行。
第一行包含一个正整数n(小于等于10000),代表会员人数。
第二行包含n个正整数(小于等于10000),代表各会员AC的题数。
输出
对应每组数据,如果超过一半的会员AC的题数相同,则输出这个题数,否则输出0。
样例输入
7
14 36 14 14 14 3 8
10
56 56 56 56 3 35 35 8 77 56
样例输出
14
0 展开
3个回答
展开全部
这种题目一直不知道针对它的测试程序怎么判断结束输入的...
#include <stdio.h>
#include <windows.h>
#include <time.h>
//将有二个有序数列a[first...mid]和a[mid...last]合并。
void mergearray(int a[], int first, int mid, int last, int temp[])
{
int i = first, j = mid + 1;
int m = mid, n = last;
int k = 0;
while (i <= m && j <= n)
{
if (a[i] <= a[j])
temp[k++] = a[i++];
else
temp[k++] = a[j++];
}
while (i <= m)
temp[k++] = a[i++];
while (j <= n)
temp[k++] = a[j++];
for (i = 0; i < k; i++)
a[first + i] = temp[i];
}
void mergesort_main(int a[], int first, int last, int temp[])
{
if (first < last)
{
int mid = (first + last) / 2;
mergesort_main(a, first, mid, temp); //左边有序
mergesort_main(a, mid + 1, last, temp); //右边有序
mergearray(a, first, mid, last, temp); //再将二个有序数列合并
}
}
void merge_sort(int a[], int n)
{
int *p = (int*)malloc( n*sizeof(int) );
if ( p==NULL )
return;
mergesort_main(a, 0, n - 1, p);
free( p );
}
int main()
{
int n, *a, *b, cnt, i,j, k;
a = (int*)malloc( sizeof(int)*10001 );
b = (int*)malloc( sizeof(int)*10001 );
k = 0;
while( 1 )
{
n = 0;
if ( scanf( "%d", &n ) == EOF ) /*windows下 ctrl+z结束输入,Linux下CTRL+D*/
break;
for( i=0; i<n; i++ )
scanf( "%d", &a[i] );
merge_sort( a, n );
cnt = i = j = 0;
b[k] = 0;
for( i=0; i<n; i+=j )
{
for( j=i; a[i]==a[j]; j++ )
cnt++;
if ( cnt > n/2 )
{
b[k] = a[i];
break;
}
}
k++;
}
for( i=0; i<k; i++ )
printf( "%d\n", b[i] );
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#include <stdio.h>
main()
{
int count;
int ac[10000];
int i,j,k;
int ac_same;
int ac_same_count;
count = 0;
ac_same = 0;
ac_same_count = 0;
scanf("%d\n", &count);
if (count==0)
break;
for(i=0; i<count; i++)
{
scanf("%d", &ac[i]);
k=0;
for(j=0; j<i; j++)
if (ac[i] == ac[j])
k++;
if (k > ac_same_count)
{
ac_same_count=k;
ac_same = ac[i];
}
}
if (ac_same_count>0 && (ac_same_count+1) >= count/2)
printf("%d\n", ac_same);
else
printf("0\n");
}
更多追问追答
追问
求思想
OJ说答案错误
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询