鱼C论坛

 找回密码
 立即注册
查看: 1618|回复: 8

[已解决]C语言作业

[复制链接]
发表于 2020-10-23 11:11:29 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 zxcbcv 于 2020-10-25 18:17 编辑

编程:有一个讲演比赛,有n个选手m个评委,n和m由键盘输入,每位选手的得分规则是去掉一个最高分去掉一个最低分,求平均分,要求输出每位选手的各个评委分数,最高分,最低分,平均分及名次。(先输出第一名,一次类推)例如:
选手编号    评委1    评委2     .......   评委m   最高分    最低分    平均分     名次
(用数组完成)
求大神们的帮助
最佳答案
2020-10-23 14:21:19
本帖最后由 xieglt 于 2020-10-23 14:43 编辑
  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. int main()
  4. {
  5.         int i,j;
  6.         int m,n;
  7.         int *swap;
  8.         int ** arr;
  9.         int max = 0;
  10.         int min = 0;
  11.         int avg = 0;
  12.         float average = 0.0f;
  13.         char buffer[1024] = {0};
  14.         char temp[12] = {0};

  15.         printf("请输入选手个数:\n");
  16.         scanf("%d",&n);

  17.         printf("请输入评委个数:\n");
  18.         scanf("%d",&m);
  19.        
  20.         //分配一个二维数组 arr[n][m+4];
  21.         arr = (int **)malloc(n * sizeof(int *));
  22.         for(i=0 ; i<n ; i++)
  23.         {
  24.                 //m+4 多出来的4分别用来存储选手编号、最大值、最小值、平均分
  25.                 arr[i] = (int *)malloc((m+4) * sizeof(int));
  26.         }
  27.        
  28.         //循环输入每个选手的成绩
  29.         for(i=0 ; i<n ; i++)
  30.         {
  31.                 max = 0;
  32.                 min = 0X7FFFFFFF;
  33.                 avg = 0;

  34.                 printf("请输入第 %d 位选手的成绩:\n",i+1);
  35.                 //arr[i][0]存储选手编号
  36.                 arr[i][0] = i+1;
  37.                
  38.                 //arr[i][1~m]存储每个评委的打分
  39.                 for(j=1; j<=m; j++)
  40.                 {
  41.                         printf("请输入第 %d 委评委的打分:",j);
  42.                         scanf("%d",&arr[i][j]);
  43.                        
  44.                         //求最高分
  45.                         max = max > arr[i][j] ? max : arr[i][j];
  46.                         //求最低分
  47.                         min = min < arr[i][j] ? min : arr[i][j];
  48.                         //成绩求和
  49.                         avg += arr[i][j];
  50.                 }
  51.                 //arr[i][m+1]保存最高分
  52.                 arr[i][m+1] = max;
  53.                 //arr[i][m+2]保存最低分
  54.                 arr[i][m+2] = min;
  55.                 //arr[i][m+3]保存扣掉最高分和最低分的成绩和
  56.                 arr[i][m+3] = avg - max - min;
  57.         }
  58.        
  59.         //以 扣掉最高分和最低分的成绩和 为关键字进行冒泡排序
  60.         for(i=0 ; i<n ; i++)
  61.         {
  62.                 for(j=0 ; j<n-i-1 ; j++)
  63.                 {
  64.                         if(arr[j][m+3] < arr[j+1][m+3])
  65.                         {
  66.                                 swap = arr[j];
  67.                                 arr[j] = arr[j+1];
  68.                                 arr[j+1] = swap;
  69.                         }
  70.                 }
  71.         }

  72.         //选手编号    评委1    评委2     .......   评委m   最高分    最低分    平均分
  73.         for(i=1 ; i<=m ; i++)
  74.         {
  75.                 sprintf(temp,"评委%d  ",i);
  76.                 sprintf(buffer,"%s%s",buffer,temp);
  77.         }
  78.         //输出表头
  79.         printf("选手编号  %s最高分  最低分  平均分  名次\n",buffer);
  80.        
  81.         //循环输出每一位选手的成绩
  82.         for(i=0 ; i<n ; i++)
  83.         {
  84.                 for(j=0; j<m+3; j++)
  85.                 {
  86.                         printf("%d\t",arr[i][j]);
  87.                 }
  88.                
  89.                 //计算平均分,当评委小于等于2个时,除数可能为0或者负数,注意排除
  90.                 average = (float)arr[i][m+3] / (float)(m-2 <= 0 ? 1 : m-2);
  91.                 //输出平均分
  92.                 printf("%0.2f\t",average);
  93.                 //输出名次
  94.                 printf("%d\n",i+1);
  95.         }
  96.        

  97.         //释放内存
  98.         for(i=0 ; i<n; i++)
  99.         {
  100.                 free(arr[i]);
  101.         }
  102.         free(arr);

  103.         return 0;
  104. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-10-23 11:12:30 | 显示全部楼层

回帖奖励 +5 鱼币

看一看啦
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-10-23 11:21:41 | 显示全部楼层

回帖奖励 +5 鱼币

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-10-23 14:21:19 | 显示全部楼层    本楼为最佳答案   
本帖最后由 xieglt 于 2020-10-23 14:43 编辑
  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. int main()
  4. {
  5.         int i,j;
  6.         int m,n;
  7.         int *swap;
  8.         int ** arr;
  9.         int max = 0;
  10.         int min = 0;
  11.         int avg = 0;
  12.         float average = 0.0f;
  13.         char buffer[1024] = {0};
  14.         char temp[12] = {0};

  15.         printf("请输入选手个数:\n");
  16.         scanf("%d",&n);

  17.         printf("请输入评委个数:\n");
  18.         scanf("%d",&m);
  19.        
  20.         //分配一个二维数组 arr[n][m+4];
  21.         arr = (int **)malloc(n * sizeof(int *));
  22.         for(i=0 ; i<n ; i++)
  23.         {
  24.                 //m+4 多出来的4分别用来存储选手编号、最大值、最小值、平均分
  25.                 arr[i] = (int *)malloc((m+4) * sizeof(int));
  26.         }
  27.        
  28.         //循环输入每个选手的成绩
  29.         for(i=0 ; i<n ; i++)
  30.         {
  31.                 max = 0;
  32.                 min = 0X7FFFFFFF;
  33.                 avg = 0;

  34.                 printf("请输入第 %d 位选手的成绩:\n",i+1);
  35.                 //arr[i][0]存储选手编号
  36.                 arr[i][0] = i+1;
  37.                
  38.                 //arr[i][1~m]存储每个评委的打分
  39.                 for(j=1; j<=m; j++)
  40.                 {
  41.                         printf("请输入第 %d 委评委的打分:",j);
  42.                         scanf("%d",&arr[i][j]);
  43.                        
  44.                         //求最高分
  45.                         max = max > arr[i][j] ? max : arr[i][j];
  46.                         //求最低分
  47.                         min = min < arr[i][j] ? min : arr[i][j];
  48.                         //成绩求和
  49.                         avg += arr[i][j];
  50.                 }
  51.                 //arr[i][m+1]保存最高分
  52.                 arr[i][m+1] = max;
  53.                 //arr[i][m+2]保存最低分
  54.                 arr[i][m+2] = min;
  55.                 //arr[i][m+3]保存扣掉最高分和最低分的成绩和
  56.                 arr[i][m+3] = avg - max - min;
  57.         }
  58.        
  59.         //以 扣掉最高分和最低分的成绩和 为关键字进行冒泡排序
  60.         for(i=0 ; i<n ; i++)
  61.         {
  62.                 for(j=0 ; j<n-i-1 ; j++)
  63.                 {
  64.                         if(arr[j][m+3] < arr[j+1][m+3])
  65.                         {
  66.                                 swap = arr[j];
  67.                                 arr[j] = arr[j+1];
  68.                                 arr[j+1] = swap;
  69.                         }
  70.                 }
  71.         }

  72.         //选手编号    评委1    评委2     .......   评委m   最高分    最低分    平均分
  73.         for(i=1 ; i<=m ; i++)
  74.         {
  75.                 sprintf(temp,"评委%d  ",i);
  76.                 sprintf(buffer,"%s%s",buffer,temp);
  77.         }
  78.         //输出表头
  79.         printf("选手编号  %s最高分  最低分  平均分  名次\n",buffer);
  80.        
  81.         //循环输出每一位选手的成绩
  82.         for(i=0 ; i<n ; i++)
  83.         {
  84.                 for(j=0; j<m+3; j++)
  85.                 {
  86.                         printf("%d\t",arr[i][j]);
  87.                 }
  88.                
  89.                 //计算平均分,当评委小于等于2个时,除数可能为0或者负数,注意排除
  90.                 average = (float)arr[i][m+3] / (float)(m-2 <= 0 ? 1 : m-2);
  91.                 //输出平均分
  92.                 printf("%0.2f\t",average);
  93.                 //输出名次
  94.                 printf("%d\n",i+1);
  95.         }
  96.        

  97.         //释放内存
  98.         for(i=0 ; i<n; i++)
  99.         {
  100.                 free(arr[i]);
  101.         }
  102.         free(arr);

  103.         return 0;
  104. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-10-25 17:57:54 | 显示全部楼层

回帖奖励 +5 鱼币


我靠,这个代码写的好好看
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-10-25 17:59:04 | 显示全部楼层

回帖奖励 +5 鱼币

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-10-25 18:01:10 | 显示全部楼层

回帖奖励 +5 鱼币

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-10-25 21:57:57 | 显示全部楼层
666
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-10-25 21:58:37 | 显示全部楼层
666
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-7-3 13:14

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表