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