题目描述
定义一个结构体,包含年月日,表示一个学生的出生日期。然后在一群学生的出生日期中找出谁的出生日期排行第二
要求:出生日期的存储必须使用结构体,不能使用其他类型的数据结构。
要求程序全过程对出生日期的输入、访问、输出都必须使用结构。
输入
第一行输入t表示有t个出生日期
每行输入三个整数,分别表示年、月、日
依次输入t个实例
输出
输出排行第二老的出生日期,按照年-月-日的格式输出
样例输入
6
1980 5 6
1981 8 3
1980 3 19
1980 5 3
1983 9 12
1981 11 23
样例输出
1980-5-3
提示
#include<bits/stdc++.h>
using namespace std;
struct node{
int year;
int month;
int day;
};
int comp(const node &s1,const node &s2)
{
if(s1.year==s2.year&&s1.month!=s2.month){
return s1.month<s2.month;
}
else if(s1.year==s2.year&&s1.month==s2.month&&s1.day!=s2.day)
{return s1.day<s2.day;}
else return s1.year<s2.year;
}
int main(){
int t;
cin>>t;
node stu[t];
node temp;
for(int i=0;i<t;i++){
int a,b,c;
cin>>a>>b>>c;
stu[i].year=a;
stu[i].month=b;
stu[i].day=c;
}
sort(stu,stu+t,comp);
cout<<stu[1].year<<"-"<<stu[1].month<<"-"<<stu[1].day;
}