年龄最小(利用C语言结构求解)

题目:

输入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;
}

​

答案百分百正确好吧嘿嘿

  • 9
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值