用c语言实现,输入n个朋友的信息,包括姓名、生日、电话号码,本题要求编写程序,按照年龄从大到小的顺序依次输出通讯录。题目保证所有人的生日均不相同。
时间: 2023-05-11 22:04:27 浏览: 132
好的,这是一个非常有趣的问题,让我来为您解答。以下是一个简单的 C 语言程序,可以实现您所描述的功能:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX_FRIENDS 100
typedef struct {
char name[50];
char birthday[20];
char phone[20];
int age;
} Friend;
int compare_friends(const void *a, const void *b) {
const Friend *fa = (const Friend *)a;
const Friend *fb = (const Friend *)b;
return fb->age - fa->age;
}
int main() {
int n;
Friend friends[MAX_FRIENDS];
printf("请输入朋友的数量:");
scanf("%d", &n);
for (int i = 0; i < n; i++) {
printf("请输入第 %d 个朋友的信息:\n", i + 1);
printf("姓名:");
scanf("%s", friends[i].name);
printf("生日:");
scanf("%s", friends[i].birthday);
printf("电话号码:");
scanf("%s", friends[i].phone);
// 计算年龄
int year, month, day;
sscanf(friends[i].birthday, "%d-%d-%d", &year, &month, &day);
friends[i].age = 2021 - year;
}
// 按照年龄从大到小排序
qsort(friends, n, sizeof(Friend), compare_friends);
// 输出通讯录
printf("通讯录如下:\n");
for (int i = 0; i < n; i++) {
printf("%s\t%s\t%s\t%d\n", friends[i].name, friends[i].birthday, friends[i].phone, friends[i].age);
}
return 0;
}
```
这个程序使用了结构体来存储每个朋友的信息,然后通过 `qsort` 函数来按照年龄从大到小排序。最后,程序输出排序后的通讯录。
希望这个程序能够满足您的需求。如果您有任何问题,请随时问我。
阅读全文