题目描述
查找和排序
题目:输入任意(用户,成绩)序列,可以获得成绩从高到低或从低到高的排列,相同成绩
都按先录入排列在前的规则处理。
例示:
jack 70
peter 96
Tom 70
smith 67
从高到低 成绩
peter 96
jack 70
Tom 70
smith 67
从低到高
smith 67
Tom 70
jack 70
peter 96
输入描述:
输入多行,先输入要排序的人的个数,然后分别输入他们的名字和成绩,以一个空格隔开
输出描述:
按照指定方式输出名字和成绩,名字和成绩之间以一个空格隔开
示例1
输入
3
0
fang 90
yang 50
ning 70
输出
fang 90
ning 70
yang 50
代码:
//第六十六题 成绩排序
#include<iostream>
#include<vector>
#include<algorithm>
#include<string>
using namespace std;
struct Student
{
string name;
int score;
};
bool compare(Student a, Student b)
{
return a.score<b.score; //升序排列,如果改为return a>b,则为降序
}
bool compare2(Student a, Student b)
{
return a.score>b.score; //降序
}
int main()
{
int num_size, mode;
while (cin >> num_size >> mode)
{
vector<Student>v_student(num_size);
int i;
for (i = 0; i < num_size; i++)
{
cin >> v_student[i].name >> v_student[i].score;
}
if(mode)
stable_sort(v_student.begin(), v_student.end(), compare);
else
stable_sort(v_student.begin(), v_student.end(), compare2);
for (i = 0; i < num_size; i++)
{
cout << v_student[i].name << " " << v_student[i].score << endl;
}
}
return 0;
}
本文介绍了一种使用C++实现的成绩排序算法,通过定义学生结构体并利用稳定排序算法,实现了成绩从高到低或从低到高的排序,同时保持了相同成绩学生的录入顺序。文章详细展示了代码实现过程。
3万+

被折叠的 条评论
为什么被折叠?



