题目描述
cjf君想调查学校OI组每个同学的生日,并按照从大到小的顺序排序。但cjf君最近作业很多,没有时间,所以请你帮她排序。
输入输出格式
输入格式:
有2行,
第1行为OI组总人数n;
第2行至第n+1行分别是每人的姓名s、出生年y、月m、日d。
输出格式:
有n行,
即n个生日从大到小同学的姓名。(如果有两个同学生日相同,输入靠后的同学先输出)
输入输出样例
输入样例#1:
3
Yangchu 1992 4 23
Qiujingya 1993 10 13
Luowen 1991 8 1
输出样例#1:
Luowen
Yangchu
Qiujingya
说明
数据规模
1<n<100
length(s)<20
思路:排序
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int n;
struct nond{
int year,month,day,id;
}child[];
char s[][];
int cmp(nond a,nond b){
if(a.year==b.year)
if(a.month==b.month)
if(a.day==b.day) return a.id>b.id;
else return a.day<b.day;
else return a.month<b.month;
else return a.year<b.year;
}
int main(){
scanf("%d",&n);
for(int i=;i<=n;i++){
scanf("%s %d%d%d",s[i],&child[i].year,&child[i].month,&child[i].day);
child[i].id=i;
}
sort(child+,child++n,cmp);
for(int i=;i<=n;i++)
cout<<s[child[i].id]<<endl;
}