用C语言写一个图书管理系统 目的:顺序表的应用 该系统含有的功能为:a、把图书按照专业进修分类,每个类的图书建立一个顺序表b、对图书的状态进行标注(数量、可借、不可借)c、如果可以借,标明馆藏地 d、如果借出,标明归还日期

时间: 2023-07-10 09:15:11 浏览: 45
以下是一个简单的图书管理系统的 C 代码,使用了顺序表来实现: ```c #include <stdio.h> #include <string.h> #include <time.h> #define MAX_BOOKS 1000 // 图书馆最大书籍数量 #define MAX_NAME_LEN 50 // 书名最大长度 #define MAX_AUTHOR_LEN 50 // 作者名最大长度 // 书籍结构体 typedef struct { char name[MAX_NAME_LEN]; char author[MAX_AUTHOR_LEN]; int count; int available; char location[20]; time_t due_date; } book_t; // 图书馆结构体 typedef struct { char name[50]; book_t books[MAX_BOOKS]; int count; } library_t; // 初始化图书馆 void init_library(library_t *library, char *name) { strcpy(library->name, name); library->count = 0; } // 添加书籍 void add_book(library_t *library, int category, char *name, char *author, int count, char *location) { book_t book; strcpy(book.name, name); strcpy(book.author, author); book.count = count; book.available = count; strcpy(book.location, location); book.due_date = 0; library->books[category * MAX_BOOKS + library->count++] = book; } // 借书 void borrow_book(library_t *library, int category, int book_index) { book_t *book = &library->books[category * MAX_BOOKS + book_index]; if (book->available > 0) { book->available--; book->due_date = time(NULL) + 7 * 24 * 60 * 60; // 归还日期为一周后 printf("借阅成功!请在 %s 归还。\n", ctime(&book->due_date)); } else { printf("该书籍已全部被借出!\n"); } } // 还书 void return_book(library_t *library, int category, int book_index) { book_t *book = &library->books[category * MAX_BOOKS + book_index]; if (book->available < book->count) { book->available++; book->due_date = 0; printf("归还成功!\n"); } else { printf("该书籍未被借出或已全部归还!\n"); } } // 显示书籍信息 void show_book_info(book_t *book) { printf("书名:%s\n", book->name); printf("作者:%s\n", book->author); printf("总数:%d\n", book->count); printf("可借:%d\n", book->available); printf("馆藏地:%s\n", book->location); if (book->due_date != 0) { printf("归还日期:%s", ctime(&book->due_date)); } } // 显示某个类别的所有书籍信息 void show_category_books(library_t *library, int category) { printf("类别:%d\n", category); printf("书籍数量:%d\n", library->count); for (int i = 0; i < library->count; i++) { book_t *book = &library->books[category * MAX_BOOKS + i]; printf("书籍编号:%d\n", i); show_book_info(book); printf("\n"); } } int main() { library_t library; init_library(&library, "图书馆"); // 模拟添加书籍 add_book(&library, 0, "C语言程序设计", "谭浩强", 10, "1A"); add_book(&library, 1, "Java编程思想", "Bruce Eckel", 5, "2B"); add_book(&library, 1, "Java核心技术", "Cay S. Horstmann", 8, "2A"); // 显示所有书籍信息 for (int i = 0; i < 2; i++) { show_category_books(&library, i); } // 借阅一本书 borrow_book(&library, 1, 0); // 归还一本书 return_book(&library, 1, 0); return 0; } ``` 这个图书管理系统使用了一个 library_t 结构体来表示整个图书馆,其中包含了一个图书数组 books,每个类别的图书都存储在一个顺序表中。通过调用 add_book 函数可以添加图书,通过调用 borrow_book 和 return_book 函数可以借阅和归还图书。通过调用 show_category_books 函数可以显示某个类别的所有书籍信息。

最新推荐

recommend-type

C语言图书管理系统简洁版

主要为大家详细介绍了C语言图书管理系统简洁版,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

C语言实现车辆出租管理系统

主要为大家详细介绍了C语言实现车辆出租管理系统,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

大一C语言课程设计图书信息管理系统.doc

大一C语言课程设计图书信息管理系统.doc
recommend-type

C语言实现食堂就餐管理系统(带链表)

主要为大家详细介绍了C语言实现食堂就餐管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

C语言实现简单航班管理系统

主要为大家详细介绍了C语言实现简单航班管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB柱状图在信号处理中的应用:可视化信号特征和频谱分析

![matlab画柱状图](https://img-blog.csdnimg.cn/3f32348f1c9c4481a6f5931993732f97.png) # 1. MATLAB柱状图概述** MATLAB柱状图是一种图形化工具,用于可视化数据中不同类别或组的分布情况。它通过绘制垂直条形来表示每个类别或组中的数据值。柱状图在信号处理中广泛用于可视化信号特征和进行频谱分析。 柱状图的优点在于其简单易懂,能够直观地展示数据分布。在信号处理中,柱状图可以帮助工程师识别信号中的模式、趋势和异常情况,从而为信号分析和处理提供有价值的见解。 # 2. 柱状图在信号处理中的应用 柱状图在信号处理
recommend-type

前端深拷贝 和浅拷贝有哪些方式,你在哪里使用过

前端深拷贝和浅拷贝的方式有很多,下面列举几种常用的方式: 深拷贝: 1. JSON.parse(JSON.stringify(obj)),该方法可以将对象序列化为字符串,再将字符串反序列化为新的对象,从而实现深拷贝。但是该方法有一些限制,例如无法拷贝函数、RegExp等类型的数据。 2. 递归拷贝,即遍历对象的每个属性并进行拷贝,如果属性值是对象,则递归进行拷贝。 3. 使用第三方库如lodash、jQuery等提供的深拷贝方法。 浅拷贝: 1. Object.assign(target, obj1, obj2, ...),该方法可以将源对象的属性浅拷贝到目标对象中,如果有相同的属性,则会
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。