假设你正在开发一个图书管理系统,你需要设计一个数据结构来表示图书。每本图书包括书名、作者和出版日期。按照出版日 期升序排序,即先出版的图书排在前面。 输入: 从键盘输入一个整数 n(1<= n<=100),表示图书数量。然后输入n行,每行包含一本图书的信息:书名(不 超过100个字符)、作者(不超过100个字符)和出版日期(格式为YYYY-MM-DD),数据之间用空格隔开。 输出:~按排序后的顺序输出图书的信息,每本图书一行,包括书名、作者和出版日期,数据之间用空格隔开。 用C语言
时间: 2024-02-13 14:07:45 浏览: 148
好的,我会尽力回答你的问题。对于这个问题,我们可以使用结构体来表示一本图书,然后将这些图书按照出版日期进行排序。
以下是一个示例代码:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX_BOOKS 100
// 定义图书结构体
struct Book {
char title[101];
char author[101];
char date[11];
};
// 按照出版日期升序排序
int cmp(const void *a, const void *b) {
return strcmp(((struct Book*)a)->date, ((struct Book*)b)->date);
}
int main() {
int n;
struct Book books[MAX_BOOKS];
// 从键盘读入图书数量和信息
scanf("%d", &n);
for (int i = 0; i < n; i++) {
scanf("%s%s%s", books[i].title, books[i].author, books[i].date);
}
// 按照出版日期排序
qsort(books, n, sizeof(struct Book), cmp);
// 输出图书信息
for (int i = 0; i < n; i++) {
printf("%s %s %s\n", books[i].title, books[i].author, books[i].date);
}
return 0;
}
```
在这个代码中,我们首先定义了一个结构体 `Book` 来表示一本图书,包含三个成员变量:`title`、`author` 和 `date`,分别表示书名、作者和出版日期。然后我们定义了一个比较函数 `cmp`,用来在排序时按照出版日期升序排列。接着我们读入图书数量和信息,使用 `qsort` 函数按照出版日期排序,最后输出排序后的图书信息。
希望这个示例代码能够对你有所帮助!如果你还有其他问题,可以继续问我。
阅读全文