鱼C论坛

 找回密码
 立即注册
查看: 1343|回复: 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 编辑
#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;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

回帖奖励 +5 鱼币

看一看啦
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

回帖奖励 +5 鱼币

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 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;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

回帖奖励 +5 鱼币


我靠,这个代码写的好好看
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

回帖奖励 +5 鱼币

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

回帖奖励 +5 鱼币

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-10-25 21:57:57 | 显示全部楼层
666
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-10-25 21:58:37 | 显示全部楼层
666
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-12 21:09

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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