c语言问题: 输入格式 输入有多组数据。 每组数据两行。 第一行包含一个正整数n(小于等于1000

2024-12-03 17:36:41
推荐回答(3个)
回答(1):

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

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

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

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

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

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

回答(2):

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

#include 
#include 
#include 
//将有二个有序数列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            scanf( "%d", &a[i] );
        merge_sort( a, n );
        cnt = i = j = 0;
        b[k] = 0;
        for( i=0; i        {
            for( j=i; a[i]==a[j]; j++ )
                cnt++;
            if (  cnt > n/2 )
            {
                b[k] = a[i];
                break;
            }
        }
        k++;
    }
    for( i=0; i        printf( "%d\n", b[i] );
}

回答(3):

#include  
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    {
         scanf("%d", &ac[i]);
         k=0;
         for(j=0; 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");
}