题解 | #成绩排序#

成绩排序

https://www.nowcoder.com/practice/0383714a1bb749499050d2e0610418b1

#include<cstdio>
#include<algorithm>

using namespace std ;

struct Student {
    char name[50];
    int grade;
    int seq;//记录录入顺序
};
bool comp0(Student lhs, Student rhs) {
    if (lhs.grade < rhs.grade) {
        return true;
    } else if (lhs.grade == rhs .grade && lhs.seq < rhs.seq) {
        return true;
    } else {
        return false;
    }
}
bool comp1(Student lhs, Student rhs) {
    if (lhs.grade > rhs.grade) {
        return true;
    } else if (lhs.grade == rhs .grade && lhs.seq < rhs.seq) {
        return true;
    } else {
        return false;
    }
}

int main() {
    int n ;
    int order; //0/1
    Student arr[1000];
    while (scanf("%d%d", &n, &order) != EOF) {
        int seq = 0;
        for (int i = 0 ; i < n ; ++i) {
            scanf("%s%d", arr[i].name, &arr[i].grade);
            arr[i].seq = seq;
            ++seq;
        }
        if (0 == order) {
            sort(arr, arr + n, comp1);
        } else if (1 == order) {
            sort(arr, arr + n, comp0);
        }
        for (int i = 0 ; i < n ; ++i) {
            printf("%s %d\n", arr[i].name, arr[i].grade);
        }
    }

}

全部评论

相关推荐

10-12 19:08
666 C++
花开蝶自来_:技能:听动物叫,让雪豹闭嘴
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务