AcWing 429. 奖学金
原题链接
简单
作者:
hai阿卢
,
2021-02-06 14:44:07
,
所有人可见
,
阅读 332
#include<iostream>
#include<algorithm>
using namespace std;
const int N=310;
struct gread{
int a,b,c;//总分,语文成绩,学号
}g[N];
//总分排序函数
bool cmp(struct gread a,struct gread b)
{
return a.a>b.a;
}
//语文成绩排序函数
bool cmp_1(struct gread a,struct gread b)
{
return a.b>b.b;
}
//学号排序函数
bool cmp_2(struct gread a,struct gread b)
{
return a.c<b.c;
}
int main()
{
int n;
cin>>n;
for(int i=0;i<n;i++)
{
int a,b,c;
cin>>a>>b>>c;
g[i].a=a+b+c,g[i].b=a,g[i].c=i;
}
//第一次,通过总分排序
sort(g,g+n,cmp);
//第二次,给相同总分的以语文成绩排序
for(int i=0;i<n;i++)
{
int y=i;
while(g[y].a==g[i].a) y++;
sort(g+i,g+y,cmp_1);
}
//第三次,给相同总分和语文成绩的以学号排序
for(int i=0;i<n;i++)
{
int y=i;
while(g[y].a==g[i].a&&g[i].b==g[y].b) y++;
sort(g+i,g+y,cmp_2);
}
for(int i=0;i<5;i++)
{
cout<<g[i].c+1<<" "<<g[i].a<<endl;
}
return 0;
}