用c语言输入n个朋友的信息,包括姓名、生日、电话号码,本题要求编写程序,按照年龄从大到小的顺序依次输出通讯录。题目保证所有人的生日均不相同。 输入格式: 输入第一行给出正整数n(<10)。随后n行,每行按照“姓名 生日 电话号码”的格式给出一位朋友的信息,其中“姓名”是长度不超过10的英文字母组成的字符串,“生日”是yyyymmdd格式的日期,“电话号码”是不超过17位的数字及+、-组成的字符串。 输出格式: 按照年龄从大到小输出朋友的信息,格式同输出。 输入样例: 3 zhang 19850403 13912345678 wang 19821020 +86-0571-88018448 qian 19840619 13609876543 输出样例: wang 19821020 +86-0571-88018448 qian 19840619 13609876543 zhang 19850403 13912345678
时间: 2023-05-11 21:04:35 浏览: 149
这是一个编程类的问题,可以回答。以下是一个可能的解法:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX_N 10
#define MAX_NAME_LEN 11
#define MAX_PHONE_LEN 18
struct Friend {
char name[MAX_NAME_LEN];
int birthday;
char phone[MAX_PHONE_LEN];
};
int compare_friends(const void *a, const void *b) {
const struct Friend *fa = (const struct Friend *)a;
const struct Friend *fb = (const struct Friend *)b;
return fb->birthday - fa->birthday;
}
int main() {
int n;
struct Friend friends[MAX_N];
scanf("%d", &n);
for (int i = 0; i < n; i++) {
scanf("%s %d %s", friends[i].name, &friends[i].birthday, friends[i].phone);
}
qsort(friends, n, sizeof(struct Friend), compare_friends);
for (int i = 0; i < n; i++) {
printf("%s %d %s\n", friends[i].name, friends[i].birthday, friends[i].phone);
}
return 0;
}
```
解释一下:
首先定义了一个结构体 `Friend`,包含了姓名、生日和电话号码三个字段。注意姓名和电话号码的长度都有上限,需要预先定义好。
然后定义了一个比较函数 `compare_friends`,用于排序。这里采用了从大到小的顺序,即按照生日从晚到早排序。
在 `main` 函数中,先读入朋友的信息,然后调用 `qsort` 函数进行排序,最后按照顺序输出即可。
注意:这里没有进行输入格式的严格检查,实际应用中需要注意输入的合法性。