Mark11


私信TA

用户名:Mark11

访问量:450

签 名:

懒惰,傲慢,愤怒

排  名 87
经  验 3109
参赛次数 0
文章发表 47
年  龄 20
在职情况
学  校 NorthWest University
专  业 S.E

  自我简介:

从头来过的苦逼


#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;
}


  评论区