欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

成绩排序

程序员文章站 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;
}