您的位置:首页 > 产品设计 > UI/UE

1062. Talent and Virtue (25)

2017-02-22 16:13 337 查看
题目:https://www.patest.cn/contests/pat-a-practise/1062

代码:#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<cmath>
#include<stack>
#include<string>
#include<iostream>
#include<algorithm>
using namespace std;
struct stu{
char id[10];
int de,cai,sum;
int flag;
}s[100010];
bool cmp(stu a,stu b){
if(a.flag!=b.flag) return a.flag<b.flag;
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.id,b.id)<0;
}
int main()
{
int n,min,max;
scanf("%d%d%d",&n,&min,&max);
int m=n;
for(int i=0;i<n;i++){
scanf("%s%d%d",s[i].id,&s[i].de,&s[i].cai);
s[i].sum=s[i].de+s[i].cai;
if(s[i].de<min||s[i].cai<min){
s[i].flag=5;
m--;
}
else if(s[i].de>=max&&s[i].cai>=max) s[i].flag=1;
else if(s[i].de>=max&&s[i].cai<max) s[i].flag=2;
else if(s[i].de>=s[i].cai) s[i].flag=3;
else s[i].flag=4;
}
sort(s,s+n,cmp);
printf("%d\n",m);
for(int i=0;i<m;i++){
printf("%s %d %d\n",s[i].id,s[i].de,s[i].cai);
}
system("pause");
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: