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
展开
 我来答
百度网友faadf46
高粉答主

2019-07-17 · 说的都是干货,快来关注
知道答主
回答量:4556
采纳率:0%
帮助的人:75.9万
展开全部

1、首先打开visual studio软件,新建一个C语言文件。

2、接着在C语言文件的顶部导入库内容。

3、接着运用scanf函数接收用户输入的字符串

4、然后我们利用printf函数打印一下用户输入的内容。

5、运行程序以后就会弹出如下图所示的CMD界面,我们输入内容就会自动接收到,然后原样输出内容。

6、最后如果你接收其他的类型,比如整数,那么类型就需要改变成int。

sunnyhouyq
2013-12-13 · TA获得超过648个赞
知道小有建树答主
回答量:515
采纳率:100%
帮助的人:521万
展开全部

这种题目一直不知道针对它的测试程序怎么判断结束输入的...

#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] );
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
cooke1234
推荐于2018-02-26 · TA获得超过6861个赞
知道大有可为答主
回答量:4617
采纳率:72%
帮助的人:3608万
展开全部
#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说答案错误
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式