PAT:1015. 德才论 (25) AC
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
struct Student
{
char mID[10];
int de,cai,sum;
int tag; //标明是第几类:1德才都们组,2德胜才,3
}STU[100010];
bool cmp(Student a,Student b) //【warning】不能写STU
{
if(a.tag!=b.tag)
return a.tag<b.tag;
else if(a.sum!=b.sum)
return a.sum>b.sum;
else if(a.de!=b.de)
return a.de>b.de;
else
return strcmp(a.mID,b.mID)<0; //【caution】小于号勿忘!!
}
int main()
{
int n,L,H;
scanf("%d%d%d",&n,&L,&H);
int m=n; //m记录有效人数
for(int i=0 ; i<n ; ++i)
{
scanf("%s %d %d",&STU[i].mID,&STU[i].de,&STU[i].cai);
STU[i].sum=STU[i].cai+STU[i].de;
if(STU[i].de < L || STU[i].cai < L) //淘汰的人
{
STU[i].tag=5;
--m;
}
else if(STU[i].de >=H && STU[i].cai >=H )
STU[i].tag=1;
else if(STU[i].de >=H && STU[i].cai < H )
STU[i].tag=2;
else if(STU[i].de < H && STU[i].cai < H && STU[i].de >= STU[i].cai)
STU[i].tag=3;
else
STU[i].tag=4;
}
sort(STU,STU+n,cmp);
printf("%d\n",m);
for(int i=0 ; i<m ; ++i)
printf("%s %d %d\n",STU[i].mID,STU[i].de,STU[i].cai);
return 0;
}