|
发表于 2020-10-23 14:21:19
|
显示全部楼层
本楼为最佳答案
本帖最后由 xieglt 于 2020-10-23 14:43 编辑
- #include <stdio.h>
- #include <stdlib.h>
- int main()
- {
- int i,j;
- int m,n;
- int *swap;
- int ** arr;
- int max = 0;
- int min = 0;
- int avg = 0;
- float average = 0.0f;
- char buffer[1024] = {0};
- char temp[12] = {0};
- printf("请输入选手个数:\n");
- scanf("%d",&n);
- printf("请输入评委个数:\n");
- scanf("%d",&m);
-
- //分配一个二维数组 arr[n][m+4];
- arr = (int **)malloc(n * sizeof(int *));
- for(i=0 ; i<n ; i++)
- {
- //m+4 多出来的4分别用来存储选手编号、最大值、最小值、平均分
- arr[i] = (int *)malloc((m+4) * sizeof(int));
- }
-
- //循环输入每个选手的成绩
- for(i=0 ; i<n ; i++)
- {
- max = 0;
- min = 0X7FFFFFFF;
- avg = 0;
- printf("请输入第 %d 位选手的成绩:\n",i+1);
- //arr[i][0]存储选手编号
- arr[i][0] = i+1;
-
- //arr[i][1~m]存储每个评委的打分
- for(j=1; j<=m; j++)
- {
- printf("请输入第 %d 委评委的打分:",j);
- scanf("%d",&arr[i][j]);
-
- //求最高分
- max = max > arr[i][j] ? max : arr[i][j];
- //求最低分
- min = min < arr[i][j] ? min : arr[i][j];
- //成绩求和
- avg += arr[i][j];
- }
- //arr[i][m+1]保存最高分
- arr[i][m+1] = max;
- //arr[i][m+2]保存最低分
- arr[i][m+2] = min;
- //arr[i][m+3]保存扣掉最高分和最低分的成绩和
- arr[i][m+3] = avg - max - min;
- }
-
- //以 扣掉最高分和最低分的成绩和 为关键字进行冒泡排序
- for(i=0 ; i<n ; i++)
- {
- for(j=0 ; j<n-i-1 ; j++)
- {
- if(arr[j][m+3] < arr[j+1][m+3])
- {
- swap = arr[j];
- arr[j] = arr[j+1];
- arr[j+1] = swap;
- }
- }
- }
- //选手编号 评委1 评委2 ....... 评委m 最高分 最低分 平均分
- for(i=1 ; i<=m ; i++)
- {
- sprintf(temp,"评委%d ",i);
- sprintf(buffer,"%s%s",buffer,temp);
- }
- //输出表头
- printf("选手编号 %s最高分 最低分 平均分 名次\n",buffer);
-
- //循环输出每一位选手的成绩
- for(i=0 ; i<n ; i++)
- {
- for(j=0; j<m+3; j++)
- {
- printf("%d\t",arr[i][j]);
- }
-
- //计算平均分,当评委小于等于2个时,除数可能为0或者负数,注意排除
- average = (float)arr[i][m+3] / (float)(m-2 <= 0 ? 1 : m-2);
- //输出平均分
- printf("%0.2f\t",average);
- //输出名次
- printf("%d\n",i+1);
- }
-
- //释放内存
- for(i=0 ; i<n; i++)
- {
- free(arr[i]);
- }
- free(arr);
- return 0;
- }
复制代码 |
|