隔壁王健喜儿 2022-12-21 10:22 采纳率: 96%
浏览 23
已结题

C语言考试排名结构体求改错

80分,求改错

/*
某考试有5道题和1道附加题,每题最高得分20分,总分计算为所有题目分数之和。
给出一组考生的数据,对其按照总分从高到低进行排名,总分相同时按附加题得分高者优先。

输入说明
第一行为一个整数N,表示考生个数(N小于100),后面N行为考生数据,
每行包含考生姓名(长度不超过20个字符)以及6个以空格分隔的整数,
分别表示第一题到第五题以及附加题的得分(最后一项)。

输出说明
输出排序结果,每行为一个考生的姓名、总分、附加题得分,以空格分开。

输入样例
3
Kavin 20 20 20 20 20 18 
Jony 18 20 20 20 20 20 
Kaku 15 15 15 15 15 15

输出样例
Jony 118 20 
Kavin 118 18 
Kaku 90 15

*/
#include <stdio.h>
struct students
{
    char name[21];
    int a, b, c, d, e, f, sum;
};
int main()
{
    int i, j, n;
    scanf("%d", &n);
    struct students stu[100], s, t;
    for (i=0; i<n; i++)
    {
        scanf("%s %d %d %d %d %d %d", stu[i].name, &stu[i].a, 
            &stu[i].b, &stu[i].c, &stu[i].d, &stu[i].e, &stu[i].f);
        stu[i].sum=stu[i].a+stu[i].b+stu[i].c+stu[i].d+stu[i].e+stu[i].f;
    }
    for (i=0; i<n-1; i++)
    {
        for (j=i+1; j<n; j++)
        {
            if (stu[i].sum<stu[j].sum)
            {
                s=stu[i]; 
                stu[i]=stu[j];
                stu[j]=s;
            }

        }
    }
    for (i=0; i<n-1; i++)
    {
        if (stu[i].sum==stu[i+1].sum && stu[i].f<stu[i+1].f)
        {
            t=stu[i];
            stu[i]=stu[i+1];
            stu[i+1]=t;
        }
    }
    for (i=0; i<n; i++)
    {
        printf("%s %d %d\n", stu[i].name, stu[i].sum, stu[i].f);
    }
    
    return 0;
}

  • 写回答

3条回答 默认 最新

  • 快乐鹦鹉 2022-12-21 10:36
    关注
     for (i=0; i<n-1; i++)
        {
            for (j=i+1; j<n; j++)
            {
                if (stu[i].sum<stu[j].sum)
                {
                    s=stu[i]; 
                    stu[i]=stu[j];
                    stu[j]=s;
                }
    
            }
        }
        for (i=0; i<n-1; i++)
        {
            if (stu[i].sum==stu[i+1].sum && stu[i].f<stu[i+1].f)
            {
                t=stu[i];
                stu[i]=stu[i+1];
                stu[i+1]=t;
            }
        }
    
    

    改为:

     for (i=0; i<n-1; i++)
        {
            for (j=i+1; j<n; j++)
            {
                if (stu[i].sum<stu[j].sum || (stu[i].sum==stu[j].sum && stu[i].f<stu[j].f))
                {
                    s=stu[i]; 
                    stu[i]=stu[j];
                    stu[j]=s;
                }
    
            }
        }
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 12月29日
  • 已采纳回答 12月21日
  • 创建了问题 12月21日

悬赏问题

  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度