数据结构课程设计-图书管理

上传人:第*** 文档编号:55666449 上传时间:2018-10-03 格式:DOC 页数:45 大小:845.48KB
返回 下载 相关 举报
数据结构课程设计-图书管理_第1页
第1页 / 共45页
数据结构课程设计-图书管理_第2页
第2页 / 共45页
数据结构课程设计-图书管理_第3页
第3页 / 共45页
数据结构课程设计-图书管理_第4页
第4页 / 共45页
数据结构课程设计-图书管理_第5页
第5页 / 共45页
点击查看更多>>
资源描述

《数据结构课程设计-图书管理》由会员分享,可在线阅读,更多相关《数据结构课程设计-图书管理(45页珍藏版)》请在金锄头文库上搜索。

1、数据结构课程设计数据结构课程设计报告报告题目:题目:6.36.3 图书管理图书管理学 院 计算机学院 专 业 软件工程 年级班别 2012 级 2 班 学 号 3112006200 学生姓名 林迅玄 指导教师 李藜 成 绩 2014 年 7 月 1 日难度选做独立完 成率%自评5有一、需求分析一、需求分析【设计任务描述】设计一个计算机管理系统完成图书管理基本业务。图书管理基本业务活动包括:对一本书的采编入库、清除库存、借阅和归还等等。【输入的形式和输入值的范围】进入管理界面输入整型数据 0-7 选择需要的操作书号、现存量、总存量为大于零的整型数据,输入值的范围由系统整型数据范围而定。书名、作者

2、名、出版社名称为字符串类型数据,长度不大于 20。借书证号码,归还时间均先由字符串输入再由函数转换为整型数据,借书证号码长度不大于 5 位字符,归还时间长度不大于 8 位。【程序所能达到的主要功能】1.图书信息录入功能:每种书的登记内容包括书号、书名、著作者、出版社名称、现存量和总存量等。2.图书查询功能:分别可按书号、书名、作者、出版社名称查询图书,还可查询图书的当前借阅信息。3.排序功能:对书库中的图书按书号排序。4.图书修改功能:对选定图书信息进行修改。5.图书删除功能:某本书已无保留价值,将其从书库中注销。6.图书借阅功能:若图书现存量大于零,登记借阅者图书证号和归还日期,图书现存量减

3、 1。7.图书归还功能注销对借阅者的登记,改变该书的现存量。【测试数据】输入 1 进入图书录入信息:输入需要录入的图书信息的个数,依次录入以下信息书号书名作者出版社名称现存量总存量1weg55成功则输出“录入成功”错误则输出“此图书已存在!” 、 “请重新输入”输入 2 进入图书查询:1.按书号查询输入 2成功则输出错误则输出“对不起,不存在此图书!”2.按书名查询输入 c成功则输出错误则输出“对不起,不存在此图书!”3.按作者名查询4xhj447yez992sap16166rej10108ift20203dfg18185clg171711mlg13139qat141410bop88书号书名作

4、者出版社名称现存量总存量2sap1616书号书名作者出版社名称现存量总存量5clg1717输入 e成功则输出错误则输出“对不起,不存在此作者的图书!”4.按出版社名称查询输入 g成功则输出错误则输出“对不起,不存在此出版社出版的图书!”输入 4 进入图书修改输入 w正确则重新录入该书信息错误则输出“不存在此图书”输入 5 进入图书删除输入 d书号书名作者出版社名称现存量总存量1weg556rej10107yez99书号书名作者出版社名称现存量总存量1weg553dfg18185clg171711mlg1313书号书名作者出版社名称现存量总存量1weg66成功则输出“删除成功”错误则输出“你输入

5、的书名不存在,请核实后重新输入!”输入 3 进入图书排序输出输入 6 进入图书借阅输入 w成功则继续输入 错误则输出“此图书不存在!”输入 15成功则继续输入 错误则输出“输入有误,请重新输入”输入 20140101成功输出“借书成功!”错误则输出“此图书不存在!” 、 “不好意思,此书已借完!” 、 “你已经借了这本书,不能够重复借!”输入 6 进入图书借阅重复输入 w 17 20140715 w 25 20141109输入 2 进入图书查询输入 2 按书名查询书号书名作者出版社名称现存量总存量1weg662sap16164xhj445clg17176rej10107yez998ift202

6、09qat141410bop8811mlg1313输入 w成功则输出错误则输出“对不起,不存在此图书!”输入 2 进入图书查询输入 5 查询图书借阅信息输入 w成功则输出借阅者图书证号归还时间152014010117201407152520141109错误则输出“不存在此图书”输入 7 进入图书归还输入 w成功则继续输入 错误则输出“此图书不存在!”输入 17成功则输出“该书归还成功!”错误则输出“你输入的图书证号不正确!请重 新操作!”输入 2 进入图书查询输入 5 查询图书借阅信息输入 w成功则输出借阅者图书证号归还时间15201401012520141109书号书名作者出版社名称现存量总

7、存量1weg36错误则输出“不存在此图书”输入 0 退出系统成功则输出“谢谢使用”2、概要设计概要设计所用数据结构:线性表、查找、排序借阅者的存储结构体数据类型是无表头单链表。typedef struct User /借阅者的存储结构体int number; /借书证号码int limitdate; /归还时间struct User *next; /下一个借阅者User; /定义用户的的信息图书信息的存储结构是带表头单链表。typedef struct int num; /图书的书号char name20; /书名char author20; /著者char press20; /出版社名称in

8、t left; /现存量int count; /总存量User *user; /借阅该书的人ElemType; /定义书的信息typedef struct LNode /定义单链表结点类型ElemType data;struct LNode *next; LinkList;主程序流程以及各程序模块之间的调用关系:N Y 重新输入 主程序模块图书管理系统借阅者信息模块图 书 信 息 的 录 入 添 加图 书 信 息 的 查 询 模 块图 书 信 息 的 排 序 模 块图 书 信 息 的 修 改 模 块图 书 信 息 的 删 除 模 块图 书 的 借 阅 模 块图 书 的 归 还 模 块退 出 图

9、 书 管 理 系 统开始输入功能所 对应的数字输入的数字小 于 0 大于 7执 行 所 选 功 能1.图书信息录入功能YYN 2.图书查询功能YN1. NY输入需要录 入的图书信 息的个数 n循环输入 n 个图书信息是否有此图书向系统录入此书信息选择查询方式输入的数字小 于 0 大于 6执行所选功能按书号查询遍历书库查找输出书本信息不存在此书2.NY3. NY4.NY按作者查询遍历书库查找输出书本信息不存在此作者的书按书名查询遍历书库查找输出书本信息不存在此书按出版社查询遍历书库查找输出书本信息不存在此作者的书5.NY6.3.图书排序功能4.图书修改N Y5.图书删除N Y返 回查询图书借阅信

10、息遍历书库查找输出借阅信息不存在此书按书号递增有序排序 (直接插入排序法)输入书名遍历书库查找修改书本信息不存在此书输入书名遍历书库查找删除书本信息不存在此书6.图书借阅 NYYN7.图书归还NYN Y3、详细设计详细设计原理:图书管理系统要求实现许多的功能。将软件的设计任务分成许多小的功能模块进行设计。本程序经过分析分成以下几个子任务:图书信息录入、图书信息的查询、图书信息的排序、图书信息的修改、图书信息的删除、图书的借阅、图书的归还、退出图书管理系统。输入书名遍历书库查找登记信息不存在此书是否可借借出失败输入书名遍历书库查找注销信息归还不存在此书是否借过此书归还失败伪码算法:伪码算法:主程

11、序:(1)创建单链表 L,分配内存并置空;(2)输出选择菜单;(3)输入选择操作数 s;(4)Switch(s)执行所选操作;图书录入功能:(1)输入需要录入的图书信息的个数 n;(2)For(i=1;inext)(1)输入 k(与 t 对应);x=0;(2)While(若原单链表中有数据结点)if(k 不等于 p 的 t)p 指向下一个结点;else 输出 p 的信息为所找信息并指向下一个结点,x+;Endwhile(3)if(p 为空查询图书借阅信息:(1)输入 k(书名);p=L-next;x=0;(2)while(p 不为空)if(k 不等于 p 的书名)p 指向下一个结点;else

12、user 指向 p 的第一个借阅者信息结点;for(;user 不为空;user 指向下一个结点)循环输出借阅者图书证号和归还时间x 加 1;p 指向下一个结点;Endelse Endwhile(3)if(p 为空图书排序功能:(直接插入排序法)(1)p 指向 L 第一个数据结点;(2)if(若原单链表中有数据结点)r 保存*p 结点直接后继结点的指针;p 后继指针置空,构造只含一个数据结点的有序表 L;While(r 不为空)将 r 中的结点按递增顺序插入 L 中;EndwhileEndif图书修改功能:(1)输入 k(书名);p 指向 L 第一个数据结点;(2)While(若原单链表中有数

13、据结点)if(k 等于 p 的书名)p 修改信息并返回;p 指向下一个结点;Endwhile;(3)输出图书不存在;(4)返回;图书删除功能:(1)输入 k(书名);p 指向 L 第一个数据结点;q 指向 p 前驱结点;(2)while(p 不为空(3)if(p 不是最后的结点)q 指向 p 的下一个结点,删除成功;(4)if(p 是最后的结点(5)else q 下一个结点置空,删除成功;图书借阅功能:(1)输入 k(借阅书名);p 指向 L 第一个数据结点;(2)while(p 不为空(3)if(p 是最后的结点(4)else if(p 书现存量小于 1)此书已借完!;(5)else 注册借

14、阅者信息结点 s(图书证号和归还日期);if 1(p 图书尚无人借阅)借书成功;p 结点的借阅者信息结点保存 s;现存量减 1;else 1u 保存 p 结点的第一个借阅者信息结点;while(u 不为空if 2(u 为空u 下一个结点结点保存 s;现存量减 1;else if(u 的图书证号等于 s 的图书证号)不能够重复借;Endelse 1Endelse图书归还功能(1)输入 k(归还书名);p 指向 L 第一个数据结点;(2)while(p 不为空(3)if(p 是最后的结点(4)else if(k 等于 p 的书名)输入图书证号 n;user 指向 p 的第一个借阅者信息结点;if

15、1(n 等于 p 的第一个借阅者信息结点的图书证号)归还成功;p 的第一个借阅者信息结点指向下一个结点;现存量加 1;else 1while(user 后继指针不为空user 指向下一个结点;Endwhileif(user 的图书证号等于 n)归还成功;pre 的第一个结点指向 user 的下一个结点;现存量加 1;else 输入图书证号不正确,重新操作;Endelse 1Endelse函数调用关系图mainSwitch() ()CreateListR(L)Search(L)Sort(L);Display (L);ModifyList(L);ListDelete(L);Borrow(L); Return(L);InitList(L)InUserMess(user )4、调试分析调试分析(一)问题:录入图书信息后,输出图书信息时有些项目输出乱码。采取的措施:检查代码在输入语句中,定义为 int 型的项目在输入语句中加上取地址符号“ /借书证号码int limitdate; /归还时间struct User *next; /下一个借阅者User;

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 高等教育 > 大学课件

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号