题目描述
送人玫瑰手有余香,小明希望自己能带给他人快乐,于是小明在每个好友生日的时候发去一份生日祝福。小明希望将自己的通讯录按好友的生日排序排序,这样就查看起来方便多了,也避免错过好友的生日。为了小明的美好愿望,你帮帮他吧。小明的好友信息包含姓名、出生日期。其中出生日期又包含年、月、日三部分信息。输入n个好友的信息,按生日的月份和日期升序输出所有好友信息。
输入
首先输入一个整数n(1<=n<=10),表示好友人数,然后输入n行,每行包含一个好友的信息:姓名(不超过8位),以及三个整数,分别表示出生日期的年月日。
输出
按过生日的先后(月份和日期)输出所有好友的姓名和出生日期,用空格隔开,出生日期的输出格式见输出样例。
样例输入 Copy
3 Zhangling 1985 2 4 Wangliang 1985 12 11 Fangfang 1983 6 1
样例输出 Copy
Zhangling 1985-02-04 Fangfang 1983-06-01 Wangliang 1985-12-11
以下是代码实现部分:
#include <stdio.h>
#include <stdlib.h>
struct student//定义学生信息结构体
{
char name[9];//定义学生姓名
int a;//定义出生年月日
int b;
int c;
};
void jgt(struct student s[] ,int a)//用户自定义函数,用来对生日进行排序
{
struct student k;
int n1=s[0].b;
int n2=s[0].c;
int xb=0;
for(int j=0;j<a;j++)//选择排序
{
for(int i=j;i<a-1;i++)
{
if(s[i+1].b<s[j].b)
{
k=s[j];
s[j]=s[i+1];
s[i+1]=k;
}
else if(s[i+1].b==s[j].b)
{
if(s[i+1].c<s[j].c)
{
k=s[i+1];
s[i+1]=s[j];
s[j]=k;
}
}
}
}
for (int i=0;i<a;i++)
printf ("%s %d-%02d-%02d\n",s[i].name,s[i].a,s[i].b,s[i].c);
}
int main()
{
int n;
scanf ("%d",&n);
struct student s[n];
for (int i=0;i<n;i++)
{
scanf ("%s",s[i].name);
scanf ("%d %d %d",&s[i].a,&s[i].b,&s[i].c);
}//记录学生信息
jgt(s,n);//传入用户自定义函数
return 0;
}