ZZULIOJ 1181: 谁的年龄最小(结构体专题)

本文介绍了一种通过设计特定的数据结构来存储个人信息,包括姓名和详细的出生日期,并通过比较找到年龄最小的好友的方法。提供了两种不同的实现方式,利用C语言进行编程实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目描述

设计一个结构体类型,包含姓名、出生日期。其中出生日期又包含年、月、日三部分信息。输入n个好友的信息,输出年龄最小的好友的姓名和出生日期。

输入

首先输入一个整数n(1<=n<=10),表示好友人数,然后输入n行,每行包含一个好友的信息:姓名(不超过20位)以及三个整数,分别表示出生日期的年月日。

输出

输出年龄最小的好友的姓名和出生日期,用空格隔开,出生日期的输出格式见输出样例。

样例输入 Copy

3

Zhangling 1983 2 4

Wangliang 1983 12 11

Fangfang 1985 6 1

样例输出 Copy

Fangfang 1985-06-01

方法一:

#include<stdio.h>
#include<stdlib.h>
struct FRIDEND{
	char Name[20];
	int year,month,day;
};
int main()
{
	struct FRIDEND fri,max;
	max.year=0;
	max.month=0;
	max.day=-1;
	int n;
	scanf("%d",&n);
	while(n--)
	{
		scanf("%s %d %d %d",fri.Name,&fri.year,&fri.month,&fri.day);
		if(fri.year==max.year)
		{
			if(fri.month==max.month)
			{
				if(fri.day>max.day)
					max=fri;
			}
			else if(fri.month>max.month)
				max=fri;
		}
		else if(fri.year>max.year)
			max=fri;
	}
	printf("%s %04d-%02d-%02d",max.Name,max.year,max.month,max.day);
	return 0;
}

方法二:

#include<stdio.h>
#include<stdlib.h>
#include<time.h>
typedef struct student{
	char name[30];
	int a,b,c;
}STU;
int main()
{
	STU stu,max;
	int n;
	max.a=0;
	max.b=0;
	max.c=-1;
	scanf("%d",&n);
	while(n--)
	{
		scanf("%s",stu.name);
		scanf("%d %d %d",&stu.a,&stu.b,&stu.c);
		if(stu.a==max.a)
		{
			if(stu.b==max.b)
			{
				if(stu.c>max.c)
					max=stu;
			}
			else if(stu.b>max.b)
				max=stu;
		}
		else if(stu.a>max.a)
			max=stu;
	}
	printf("%s ",max.name);
	printf("%04d-%02d-%02d",max.a,max.b,max.c);
	return 0;
} 

 

### 结构体找到年龄最小的实现方法 在C/C++编程中,通过定义结构体可以方便地存储和操作具有多种属性的数据对象。为了找到一组学生中的年龄最小者,可以通过遍历数组的方式比较每位学生的年龄。 以下是基于结构体一个简单例子,用于找出年龄最小的学生: #### 实现代码 ```cpp #include <iostream> #include <string> using namespace std; // 定义学生结构体 struct Student { string name; int age; }; int main() { int n; // 学生数量 cin >> n; // 动态创建学生数组 Student students[n]; for (int i = 0; i < n; ++i) { cin >> students[i].name >> students[i].age; } // 假设第一个学生是最轻的 int minAgeIndex = 0; for (int i = 1; i < n; ++i) { if (students[i].age < students[minAgeIndex].age) { minAgeIndex = i; // 更新最轻学生的索引 } } // 输出年龄最小的学生信息 cout << "Name: " << students[minAgeIndex].name << ", Age: " << students[minAgeIndex].age << endl; return 0; } ``` 此程序首先读取`n`名学生的信息(名字和年龄),然后通过循环比较每一位学生的年龄,最终输出年龄最小的学生的名字和年龄[^1]。 --- ### 关键点解析 1. **结构体定义** 使用`struct`关键字定义了一个名为`Student`的结构体,其中包含两个成员变量:`name`(字符串类型)和`age`(整型)。这使得我们可以轻松管理每个学生的相关信息。 2. **动态数组处理** 根据输入的学生人数`n`,动态分配大小为`n`的结构体数组`students`,以便存储所有学生的信息。 3. **寻找最小值逻辑** 利用一个简单的循环逐一比较每位学生的年龄,记录当前发现的最小年龄对应的索引位置`minAgeIndex`。当遇到更小的年龄时更新该索引。 4. **边界条件考虑** 题目假设至少有一名学生参与计算,因此无需额外判断空数组的情况。如果可能有极端情况,则需增加相应验证机制[^5]。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值