PAT(甲级)1062. Talent and Virtue (25)
2017-01-25 13:21
453 查看
题目:https://www.patest.cn/contests/pat-a-practise/1062
代码:#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<algorithm>
using namespace std;
struct stu{
char id[10];
int vir;
int tal;
int sum;
int flag;
}s[100005];
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.vir!=b.vir)return a.vir>b.vir;
else return strcmp(a.id,b.id)<0;
}
int main()
{
int n,min,max,i,count;
scanf("%d%d%d",&n,&min,&max);
count=n;
for(i=0;i<n;i++){
scanf("%s%d%d",&s[i].id,&s[i].vir,&s[i].tal);
s[i].sum=s[i].tal+s[i].vir;
if(s[i].vir<min||s[i].tal<min){
s[i].flag=5;
count--;
}
else if(s[i].vir>=max&&s[i].tal>=max) s[i].flag=1;
else if(s[i].vir>=max&&s[i].tal<max) s[i].flag=2;
else if(s[i].vir>=s[i].tal) s[i].flag=3;
else s[i].flag=4;
}
sort(s,s+n,cmp);
printf("%d\n",count);
for(i=0;i<count;i++){
printf("%s %d %d\n",s[i].id,s[i].vir,s[i].tal);
}
system("pause");
} #include<cstdio>
#include<cstring>
#include<cstdlib>
#include<algorithm>
using namespace std;
struct stu{
char id[10];
int vir;
int tal;
int sum;
int flag;
}s[100005];
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.vir!=b.vir)return a.vir>b.vir;
else return strcmp(a.id,b.id)<0;
}
int main()
{
int n,min,max,i,count;
scanf("%d%d%d",&n,&min,&max);
count=n;
for(i=0;i<n;i++){
scanf("%s%d%d",&s[i].id,&s[i].vir,&s[i].tal);
s[i].sum=s[i].tal+s[i].vir;
if(s[i].vir<min||s[i].tal<min){
s[i].flag=5;
count--;
}
else if(s[i].vir>=max&&s[i].tal>=max) s[i].flag=1;
else if(s[i].vir>=max&&s[i].tal<max) s[i].flag=2;
else if(s[i].vir>=s[i].tal) s[i].flag=3;
else s[i].flag=4;
}
sort(s,s+n,cmp);
printf("%d\n",count);
for(i=0;i<count;i++){
printf("%s %d %d\n",s[i].id,s[i].vir,s[i].tal);
}
system("pause");
}
代码:#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<algorithm>
using namespace std;
struct stu{
char id[10];
int vir;
int tal;
int sum;
int flag;
}s[100005];
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.vir!=b.vir)return a.vir>b.vir;
else return strcmp(a.id,b.id)<0;
}
int main()
{
int n,min,max,i,count;
scanf("%d%d%d",&n,&min,&max);
count=n;
for(i=0;i<n;i++){
scanf("%s%d%d",&s[i].id,&s[i].vir,&s[i].tal);
s[i].sum=s[i].tal+s[i].vir;
if(s[i].vir<min||s[i].tal<min){
s[i].flag=5;
count--;
}
else if(s[i].vir>=max&&s[i].tal>=max) s[i].flag=1;
else if(s[i].vir>=max&&s[i].tal<max) s[i].flag=2;
else if(s[i].vir>=s[i].tal) s[i].flag=3;
else s[i].flag=4;
}
sort(s,s+n,cmp);
printf("%d\n",count);
for(i=0;i<count;i++){
printf("%s %d %d\n",s[i].id,s[i].vir,s[i].tal);
}
system("pause");
} #include<cstdio>
#include<cstring>
#include<cstdlib>
#include<algorithm>
using namespace std;
struct stu{
char id[10];
int vir;
int tal;
int sum;
int flag;
}s[100005];
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.vir!=b.vir)return a.vir>b.vir;
else return strcmp(a.id,b.id)<0;
}
int main()
{
int n,min,max,i,count;
scanf("%d%d%d",&n,&min,&max);
count=n;
for(i=0;i<n;i++){
scanf("%s%d%d",&s[i].id,&s[i].vir,&s[i].tal);
s[i].sum=s[i].tal+s[i].vir;
if(s[i].vir<min||s[i].tal<min){
s[i].flag=5;
count--;
}
else if(s[i].vir>=max&&s[i].tal>=max) s[i].flag=1;
else if(s[i].vir>=max&&s[i].tal<max) s[i].flag=2;
else if(s[i].vir>=s[i].tal) s[i].flag=3;
else s[i].flag=4;
}
sort(s,s+n,cmp);
printf("%d\n",count);
for(i=0;i<count;i++){
printf("%s %d %d\n",s[i].id,s[i].vir,s[i].tal);
}
system("pause");
}
相关文章推荐
- PAT - 甲级 - 1062. Talent and Virtue (25)(排序)
- PAT 1062. Talent and Virtue (25) sort应用
- 【PAT】【Advanced Level】1062. Talent and Virtue (25)
- PAT 1062. Talent and Virtue (25)(判断是否是圣人君子小人)(代码超时)
- PAT 1062. Talent and Virtue (25)
- 【C++】PAT (advanced level)1062. Talent and Virtue (25)
- PAT_B_1015. 德才论 (25) or PAT_A_1062. Talent and Virtue (25)
- PAT (Advanced Level) Practise 1062 Talent and Virtue (25)
- PAT甲题题解-1062. Talent and Virtue (25)-排序水题
- 【PAT】1062. Talent and Virtue (25)
- PAT 1062. Talent and Virtue (25)
- PAT-A-1062. Talent and Virtue (25)
- pat 1062. Talent and Virtue (25)
- pat 1062. Talent and Virtue (25)
- PAT (Advanced Level) Practise 1062 Talent and Virtue (25)
- 1062. Talent and Virtue (25)【排序】——PAT (Advanced Level) Practise
- 1062. Talent and Virtue (25)【排序】——PAT (Advanced Level) Practise
- PAT-A 1062. Talent and Virtue (25)
- PAT--1062. Talent and Virtue
- 1062. Talent and Virtue (25)