注册 登录
编程论坛 C语言论坛

pta上的一道题,写完代码总是报错,求大神帮忙改改代码

卡啊卡 发布于 2020-05-04 11:49, 2603 次点击
一群人坐在一起,每人猜一个 100 以内的数,谁的数字最接近大家平均数的一半就赢。本题就要求你找出其中的赢家。

输入格式:
输入在第一行给出一个正整数N(≤10
​4
​​ )。随后 N 行,每行给出一个玩家的名字(由不超过8个英文字母组成的字符串)和其猜的正整数(≤ 100)。

输出格式:
在一行中顺序输出:大家平均数的一半(只输出整数部分)、赢家的名字,其间以空格分隔。题目保证赢家是唯一的。

输入样例:
7
Bob 35
Amy 28
James 98
Alice 11
Jack 45
Smith 33
Chris 62

      
   
输出样例:
22 Amy
我的代码如下:
#include <stdio.h>
#include <math.h>
#include <string.h>
int main()
{
  int i,N,num[10000],sum=0;
  float half,min,eve,c[10000],d[10000],t;
  char name[10000][10],minname[10],tname[10];
  scanf("%d",&N);
  for(i=0;i<N;i++)
  {
    scanf("%s",name[i][10]);
    scanf("%d",&num[i]);
  }
  for(i=0;i<N;i++)
  {
    sum+=num[i];
  }
  eve=sum*1.0/N;
  half=eve/2;
  for(i=0;i<N;i++)
  {
    c[i]=num[i]-half;
    d[i]=fabs(c[i]);
  }
  for(i=0;i<N;i++)
  {
    min=d[0];
    minname[10]=name[0][10];
    if(min>d[i])
    {
      t=d[i];
      d[i]=min;
      min=t;
      tname[10]=name[i][10];
      name[i][10]=minname[10];
      minname[10]=tname[10];
    }
  }
  printf("%d %s",half,minname[10]);
  return 0;
}
7 回复
#2
rjsp2020-05-04 13:37
scanf("%s",name[i][10]);
我猜你想要的是 scanf("%s",name[i]);

minname[10]=name[0][10];
……
tname[10]=name[i][10];
name[i][10]=minname[10];
minname[10]=tname[10];
怎么说你呢?
#3
rjsp2020-05-04 13:56
程序代码:
#include <stdio.h>
#include <limits.h>

int main( void )
{
    unsigned n;
    scanf( "%u", &n );

    char names[10000][9];
    unsigned nums[10000];
    for( unsigned i=0; i!=n; ++i )
        scanf( "%s%u", names[i], &nums[i] );

    unsigned sum = 0;
    for( unsigned i=0; i!=n; ++i )
        sum += nums[i];

    unsigned min_index = 0;
    unsigned min_delta = UINT_MAX;
    for( unsigned i=0; i!=n; ++i )
    {
        unsigned delta = nums[i]*2*n<sum ? sum-nums[i]*2*n : nums[i]*2*n-sum;
        if( min_delta > delta  )
        {
            min_delta = delta;
            min_index = i;
        }
    }

    printf( "%u %s\n", sum/n/2, names[min_index] );
}
#4
卡啊卡2020-05-04 14:19
回复 2楼 rjsp
您的意思是不是所有类似name[i][10]表示成name[i]即可,修改了这部分之后还是报错
#5
卡啊卡2020-05-04 14:21
回复 2楼 rjsp
麻烦帮忙看一下还有其他地方有错吗,以下是我修改之后的代码
#include <stdio.h>
#include <math.h>
#include <string.h>
int main()
{
  int i,N,num[10000],sum=0;
  float half,min,eve,c[10000],d[10000],t;
  char name[10000][10],minname[10],tname[10];
  scanf("%d",&N);
  for(i=0;i<N;i++)
  {
    scanf("%s",name[i]);
    scanf("%d",&num[i]);
  }
  for(i=0;i<N;i++)
  {
    sum+=num[i];
  }
  eve=sum*1.0/N;
  half=eve/2;
  for(i=0;i<N;i++)
  {
    c[i]=num[i]-half;
    d[i]=fabs(c[i]);
  }
  for(i=0;i<N;i++)
  {
    min=d[0];
    minname[10]=name[0];
    if(min>d[i])
    {
      t=d[i];
      d[i]=min;
      min=t;
      tname[10]=name[i];
      name[i]=minname[10];
      minname[10]=tname[10];
    }
  }
  printf("%d %s",half,minname[10]);
  return 0;
}
#6
wmf20142020-05-04 14:34
"printf("%d %s",half,minname[10]);",half是个浮点数,不能用%d格式显示,minname[10]是一个字符值,且数组越界。还是去把基础打牢吧。
找一个最小值,不需要交换数据,记住数组下标就行了,为最大限度与你代码合拍,后面找最小值的代码如下:
程序代码:
//...复制你自己前面的代码就行了
    min = d[0];
    for (i = 0; i < N; i++)
    {
        if (min > d[i])
        {
            min = d[i];
            t = i;
        }
    }
    printf("%d %s\n", (int)half, name[int(t)]);
    return 0;
#7
bcbbcclbbc2020-05-04 17:08
回复 5楼 卡啊卡
至少这一节代码有逻辑问题
程序代码:
for(i=0;i<N;i++)
  {
    min=d[0];             //每次循环都给min赋一个值,怎么求得最值????
                           
//最后得出的也只是比d[0]小的一个数,这是你想要的。
    minname[10]=name[0][10];       //字符数组怎么使用,赋值,显然你还没学会,前面已经提示你name[i]
    if(min>d[i])
    {
      t=d[i];
      d[i]=min;
      min=t;
      tname[10]=name[i][10];
      name[i][10]=minname[10];
      minname[10]=tname[10];
    }
  }

上面r版主已经给出了一个完整的程序,完全可以阅读吸收,而不应该死盯着自己的
#8
生命太短暂2020-05-04 18:28
不要写那么多变量名,看着挺晕的

#include <stdio.h>
#include <math.h>
#include <string.h>
int main()
{
  
  int N;
  scanf("%d",&N);
  int num[10000];
  char name[10000][10];
  for(int i=0;i<N;i++)
  {
    scanf("%s",name[i]);
    scanf("%d",&num[i]);
  }
  int sum=0;
  for(int i=0;i<N;i++)
  {
    sum+=num[i];
  }
  
 int half=sum/N/2;int min=fabs(num[0]-half);
 int tem[10000];size_t p=0;
  for(int i=0;i<N;i++)
  { tem[i]=num[i];
  if(min>fabs(num[i]-half))
  {    min=fabs(num[i]-half);
        p=i;
      }
   
  }
  printf("%d %s",half,name[p]);
  return 0;
}
1