成绩排序
程序员文章站
2024-03-21 19:51:16
...
查找和排序
题目:输入任意(用户,成绩)序列,可以获得成绩从高到低或从低到高的排列,相同成绩
都按先录入排列在前的规则处理。
示例:
jack 70
peter 96
Tom 70
smith 67
从高到低 成绩
peter 96
jack 70
Tom 70
smith 67
从低到高
smith 67
jack 70
Tom 70
peter 96
输入描述:
输入多行,先输入要排序的人的个数,然后输入排序方法0(降序)或者1(升序)再分别输入他们的名字和成绩,以一个空格隔开
输出描述:
按照指定方式输出名字和成绩,名字和成绩之间以一个空格隔开
示例1
输入
3 0 fang 90 yang 50 ning 70
输出
fang 90 ning 70 yang 50
AC_CODE:
#include<bits/stdc++.h>
#define N 10005
using namespace std;
int n, x;
struct Stu
{
string name;
int score;
}stu[N];
int cmp(Stu a, Stu b)
{
return a.score < b.score;
}
int comp(Stu a, Stu b)
{
return a.score > b.score;
}
int main()
{
cin >> n >> x;
for (int i = 1; i <= n; i++)
{
cin >> stu[i].name;
cin >> stu[i].score;
}
if (x == 1) stable_sort(stu + 1, stu + n + 1, cmp);//稳定排序顺序不变
if (x == 0) stable_sort(stu + 1, stu + n + 1, comp);//稳定排序顺序不变
for (int i = 1; i <= n; i++)
{
cout << stu[i].name << ' ' << stu[i].score << endl;
}
return 0;
}