#include<cstdio>
#include<cstring>
#include<algorithm>
const int maxn = 100;
using namespace std;
struct Student{
    char id[10];        //学号
    char name[20];      //名字
    int score_1;        //成绩1
    int score_2;        //成绩2
    int score_3;        //成绩3
    int score_sum;      //总成绩
}stu[maxn];
bool cmp(Student a, Student b){
    if(a.score_sum != b.score_sum)      //按三科成绩总分排名
        return a.score_sum > b.score_sum;
    else        //若总分相同,按名字的字典序排名,不可能既同名又同分数吧?
        return strcmp(a.name, b.name) < 0;
}       //这里只要知道第一名就够了,就不深入讨论了
int main(){
    int n;
    int sum_1 = 0, sum_2 = 0, sum_3 = 0;      //三科的各个总分
    scanf("%d", &n);
    for(int i = 0 ; i < n; i++){
        scanf("%s %s %d %d %d", stu[i].id, stu[i].name, &stu[i].score_1, &stu[i].score_2, &stu[i].score_3);
        stu[i].score_sum = (stu[i].score_1 + stu[i].score_2 + stu[i].score_3);
        sum_1 += stu[i].score_1;
        sum_2 += stu[i].score_2;
        sum_3 += stu[i].score_3;
    }
    sort(stu, stu + n, cmp);        //按总分排序,总分最高排在第一位
    printf("%d %d %d\n", sum_1 / n, sum_2 / n, sum_3 / n);
    printf("%s %s %d %d %d\n", stu[0].id, stu[0].name, stu[0].score_1, stu[0].score_2, stu[0].score_3);
    return 0;
}


点赞(1)
 

0.0分

2 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论