题目描述
用一维数组存储学号和成绩,然后,按成绩排序输出。输入描述:
输入第一行包括一个整数N(1<=N<=100),代表学生的个数。 接下来的N行每行包括两个整数p和q,分别代表每个学生的学号和成绩。
输出描述:
按照学生的成绩从小到大进行排序,并将排序后的学生信息打印出来。 如果学生的成绩相同,则按照学号的大小进行从小到大排序。示例1
输入
复制3 1 90 2 87 3 92
输出
复制2 87 1 90 3 92
代码:
#include <iostream> #include <vector> #include <algorithm> using namespace std; struct student { int id; int score; }; bool cmp(const student &stu1, const student &stu2) { if (stu1.score < stu2.score) { return true; } if (stu1.score == stu2.score&&stu1.id < stu2.id) { return true; } return false; } int main() { int N; cin >> N; vector<student> stu; stu.resize(N); for (int i = 0 ; i < N ; i++) { cin >> stu[i].id >> stu[i].score; } stable_sort(stu.begin(), stu.end(), cmp); for (int i = 0; i < N; i++) { cout << stu[i].id << " " << stu[i].score << endl; } system("pause"); return 0; }View Code