题解 | #成绩排序#

成绩排序

https://www.nowcoder.com/practice/3f27a0a5a59643a8abf0140b9a8cf1f7

#include<iostream>
#include<algorithm>
#include<vector>

struct Student
{
    int num;
    int grade;
    Student(int n, int g)
        : num(n), grade(g)
    {
    }   
};

bool compare(const Student& a, const Student& b)
{
    if(a.grade < b.grade)
    {
        return true;
    }else if(a.grade > b.grade)
    {
        return false;
    }

    return a.num < b.num;
}

int main()
{
    int n;
    std::cin >> n;
    std::vector<Student> students;
    students.reserve(n);//预先指定要分配的内存数量
    for(int i = 0;i < n;i++)
    {
        int p,q;
        std::cin >> p >> q;
        students.emplace_back(p, q);//直接传递参数,利用构造函数,而不是传递对象,避免复制加快执行速度
    }
    std::sort(students.begin(), students.end(), compare);
    for(Student student : students)
    {
        std::cout << student.num << " " << student.grade << "\n";
    }
}

全部评论

相关推荐

jack_miller:杜:你不用我那你就用我的美赞臣
点赞 评论 收藏
分享
11-15 19:28
已编辑
蚌埠坦克学院 硬件开发
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务