题目:
输入n个学生的姓名和对应的生日(格式:年-月-日),输出年龄最小的学生的姓名(假设该学生是唯一的)。
输入格式:
输入整数n,然后输入n个人的姓名(字符个数不超过30)和对应的生日(格式:年-月-日,年月日都是整数)。
输出格式:
年龄最小的学生的姓名。
输入样例:
4
zhang 2000-12-11
wang 2000-12-2
li 2000-12-1
zhao 2000-12-3
输出样例:
zhang
思路:
1、循环输入有姓名和生日即两种类型的数据,我们可以采用简单的结构体循环达到一次性输入的目的 。
2、题目要求寻找最小年龄的学生,按要求可知一次性循环便能找到所需结果。首先找到一个初始值作为目前最小值min(可以选取第一个输入的数据),然后利用循环不断进行比大小,将小的值赋给目前最小值min,循环结束得到的min即为最小年龄学生信息。
注意:比大小时数字越小年龄越大!
代码1
#include<stdio.h>
struct student{
char name[29];
int year,month,day;
};
int main(){
int n,i,j;
scanf("%d",&n);
struct student stu[n];
for(i=0;i<n;i++){
scanf("%s %d-%d-%d\n",stu[i].name,&stu[i].year,&stu[i].month,&stu[i].day);
}
int index = 0;
for(j=1;j<n;j++){
if(stu[index].year<stu[j].year)
index=j;
else if(stu[index].year==stu[j].year && stu[index].month<stu[j].month)
index=j;
else if(stu[index].year==stu[j].year && stu[index].month==stu[j].month && stu[index].day<stu[j].day)
index=j;
}
printf("%s",stu[index].name);
return 0;
}
代码2:
#include<stdio.h>
struct student{
char name[29];
int year,month,day;
};
int main(){
int n,i,j;
scanf("%d",&n);
struct student stu,min;
for(i=1;i<=n;i++){
scanf("%s %d-%d-%d\n",stu.name,&stu.year,&stu.month,&stu.day);
if(i==1)
min=stu;
else if(stu.year>min.year)
min=stu;
else if(stu.year==min.year && stu.month>min.month)
min=stu;
else if(stu.year==min.year && stu.month==min.month && stu.day>min.day)
min=stu;
}
printf("%s",min.name);
return 0;
}
答案百分百正确好吧嘿嘿