题目描述
注:此题目应有循环输入,但是题目上没有写出来
查找和排序
题目:输入任意(用户,成绩)序列,可以获得成绩从高到低或从低到高的排列,相同成绩
都按先录入排列在前的规则处理。
示例:
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:
#include<bits/stdc++.h>
#define N 100005
using namespace std;
int n,x;
struct Stu
{
char name[100];
int score;
int turn;
}stu[N];
int cmp(const Stu &a,const Stu &b)
{
if(a.score!=b.score)
return a.score<b.score;
else
{
return a.turn<b.turn;
}
}
int comp(const Stu &a,const Stu &b)
{
if(a.score!=b.score)
return a.score>b.score;
else
{
return a.turn<b.turn;
}
}
int main()
{
while(cin>>n>>x)
{
for(int i=1;i<=n;i++)
{
scanf("%s",stu[i].name);
cin>>stu[i].score;
stu[i].turn=i;
}
if(x==1) sort(stu+1,stu+n+1,cmp);
if(x==0) sort(stu+1,stu+n+1,comp);
for(int i=1;i<=n;i++)
{
cout<<stu[i].name<<' '<<stu[i].score<<endl;
}
}
return 0;
}
可以看到,此时定义了一个turn,来记录录入顺序,因为题上要求在成绩相等时按录入顺序排序,而测试样例sort之后有一组按照了字母顺序排,不是很明白。 所以定义了一个turn来控制。
#include<bits/stdc++.h>
#define N 100005
using namespace std;
int n,x;
struct Stu
{
char name[100];
int score;
}stu[N];
int cmp(const Stu &a,const Stu &b)
{
return a.score<b.score;
}
int comp(const Stu &a,const Stu &b)
{
return a.score>b.score;
}
int main()
{
while(cin>>n>>x)
{
for(int i=1;i<=n;i++)
{
scanf("%s",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;
}
这是学长告知的一种,改成stable_sort,就可以在成绩相等的情况下保证按录入顺序排序。
知识点:sort()函数,引用,对结构体排序,stable_sort().