| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2354 人关注过本帖
标题:pta上的一道题,写完代码总是报错,求大神帮忙改改代码
只看楼主 加入收藏
卡啊卡
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2020-5-4
结帖率:0
收藏
已结贴  问题点数:20 回复次数:7 
pta上的一道题,写完代码总是报错,求大神帮忙改改代码
一群人坐在一起,每人猜一个 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;
}
搜索更多相关主题的帖子: i++ 输出 min 代码 name 
2020-05-04 11:49
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9031
专家分:54061
注 册:2011-1-18
收藏
得分:5 
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];
怎么说你呢?
2020-05-04 13:37
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9031
专家分:54061
注 册:2011-1-18
收藏
得分:0 
程序代码:
#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] );
}
2020-05-04 13:56
卡啊卡
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2020-5-4
收藏
得分:0 
回复 2楼 rjsp
您的意思是不是所有类似name[i][10]表示成name[i]即可,修改了这部分之后还是报错
2020-05-04 14:19
卡啊卡
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2020-5-4
收藏
得分:0 
回复 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;
}
2020-05-04 14:21
wmf2014
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:216
帖 子:2039
专家分:11273
注 册:2014-12-6
收藏
得分:5 
"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;

能编个毛线衣吗?
2020-05-04 14:34
bcbbcclbbc
Rank: 7Rank: 7Rank: 7
等 级:贵宾
威 望:11
帖 子:194
专家分:528
注 册:2019-8-15
收藏
得分:5 
回复 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版主已经给出了一个完整的程序,完全可以阅读吸收,而不应该死盯着自己的
2020-05-04 17:08
生命太短暂
Rank: 2
等 级:论坛游民
帖 子:16
专家分:15
注 册:2020-4-30
收藏
得分:5 
不要写那么多变量名,看着挺晕的

#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;
}
2020-05-04 18:28
快速回复:pta上的一道题,写完代码总是报错,求大神帮忙改改代码
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.019347 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved