题解 | #成绩排序#

成绩排序

https://www.nowcoder.com/practice/8e400fd9905747e4acc2aeed7240978b

#include <bits/stdc++.h>
using namespace std;

class bigger{
public:
    bool operator()(const pair<string, int>& a, const pair<string, int>& b) const{
        return a.second > b.second;
    }
};

class smaller{
public:
    bool operator()(const pair<string, int>& a, const pair<string, int>& b) const{
        return a.second < b.second;
    }
};

int main() {
    int n;
    cin >> n;
    int flag;
    cin >> flag;
    string name;
    int score;
    vector<pair<string, int>> vec;
    while(n--){
        cin >> name;
        cin >> score;
        vec.emplace_back(name, score);
    }
    if(flag == 0){
        std::stable_sort(vec.begin(), vec.end(), bigger());
    }
    else{
        std::stable_sort(vec.begin(), vec.end(), smaller());
    }
    for(auto &val : vec){
        cout << val.first << " " << val.second << endl;
    }
}
// 64 位输出请用 printf("%lld")

全部评论

相关推荐

03-28 16:43
佛山大学 Java
java全国可飞:简历2.0,各位佬看看,这样可以吗查看图片
点赞 评论 收藏
分享
求好运眷顾🙏🏻:翻译:面试前没盘点好hc一下面太多了,现在在排序回去等通知
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务