本帖最后由 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;
}
|