用c语言进行编程:输入n个朋友的信息,包括姓名、生日、电话号码,本题要求编写程序,按照年龄从大到小的顺序依次输出通讯录。题目保证所有人的生日均不相同。 输入格式: 输入第一行给出正整数n(<10)。随后n行,每行按照“姓名 生日 电话号码”的格式给出一位朋友的信息,其中“姓名”是长度不超过10的英文字母组成的字符串,“生日”是yyyymmdd格式的日期,“电话号码”是不超过17位的数字及+、-组成的字符串。 输出格式: 按照年龄从大到小输出朋友的信息,格式同输出
时间: 2024-03-18 19:40:56 浏览: 73
以下是另一种用 C 语言编写的解决方案:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
struct friend {
char name[11];
int year;
int month;
int day;
char phone[18];
};
int compare(const void *a, const void *b) {
struct friend *fa = (struct friend *)a;
struct friend *fb = (struct friend *)b;
if (fa->year != fb->year) {
return fb->year - fa->year;
} else if (fa->month != fb->month) {
return fb->month - fa->month;
} else {
return fb->day - fa->day;
}
}
int main() {
int n;
scanf("%d", &n);
struct friend f[n];
for (int i = 0; i < n; i++) {
scanf("%s %4d%2d%2d %s", f[i].name, &f[i].year, &f[i].month, &f[i].day, f[i].phone);
}
qsort(f, n, sizeof(struct friend), compare);
for (int i = 0; i < n; i++) {
printf("%s %04d%02d%02d %s\n", f[i].name, f[i].year, f[i].month, f[i].day, f[i].phone);
}
return 0;
}
```
解释:
同样地,首先定义一个结构体 `friend`,存储朋友信息,包括姓名、生日和电话号码。然后读入朋友信息。接着用 `qsort` 函数对朋友信息进行排序,排序方式是按照年龄从大到小的顺序。最后按照排序后的顺序输出朋友信息。
注意,这里用 `scanf` 函数读入生日字符串时,直接按照 `"%4d%2d%2d"` 的格式读入年、月、日,然后将其存储为整数类型。在比较函数中,按照年、月、日的顺序进行比较。输出时,需要将年、月、日分别输出,并在输出年时补齐前导零。
阅读全文