数据结构课程设计报告图书管理系统实验报告.doc
《数据结构课程设计报告图书管理系统实验报告.doc》由会员分享,可在线阅读,更多相关《数据结构课程设计报告图书管理系统实验报告.doc(21页珍藏版)》请在课桌文档上搜索。
1、目录一. 设计题目二. 设计目的三. 实验分工四. 算法思想分析五. 算法描述实现1.数据结构类型定义 2.算法流程图 3.程序代码六. 运行结果七.结论一. 设计题目图书管理基本业务模拟图书管理一般包括图书采编、图书编目、图书查询及图书流通(借、还书)等基本业务。要求设计一个图书管理信息系统,用计算机模拟实现上述系统功能。(1)书的登记内容包括书号、书名、著作者、现存量和库存量等;学生信息包括借书证号、借阅信息等;(2)以书号建立索引表(线性表)以提高查找效率;(3)主要功能如下:a) 采编入库:新购一种书,确定书号后,登记到图书帐目表中,如果表中已有,则只将库存量增加;b) 借阅:如果一种
2、书的现存量大于0,则借出一本,登记借阅者的书号和归还期限,改变现存量;c) 归还:注销对借阅者的登记,改变该书的现存量。(4)输出形式:能按书号、书名、著作者查找库存的书籍信息能按学生的借书证号显示学生信息和借阅信息书籍入库借书功能实现还书功能实现二. 设计目的1 了解并掌握数据结构与算法的设计方法,具备初步的独立分析和设计能力;2初步掌握软件开发过程的问题分析、系统设计、程序编码、测试等基本方法和技能;3提高综合运用所学的理论知识和方法独立分析和解决问题的能力;4训练用系统的观点和软件开发一般规范进行软件开发,培养软件工作者所应具备的科学的工作方法和作风。2 开发环境:VC6.0或者DEV
3、C+.三. 实验分工范文虎:总体程序框架构思,算法分析,主程序编写,子函数调用,图书信息记录存储子函数编写,结合,主控制面板编写,哈希函数,结构体定义。算法实现,添加图书信息子函数编写,借阅图书字函数编写,查询子函数设计编写,还书子函数设计编写,最终程序调试,写报告。算法实现,删除图书子函数设计编写,查找图书信息子函数编写,测试整体程序,程序缺陷纠正,最终修改后程序综合。算法实现,查询图书信息子函数设计编写,程序缺陷修改和测试。四. 算法思想分析用线性表进行存储,充分利用它易添加、易删除、查找方便的特点,进行程序的编写,符合题目的需求。而线性表是最基本、最简单、也是最常用的一种数据结构。五.
4、算法描述实现1. 数据结构类型定义typedefstruct int year; int month; int day; data;typedefstruct char num5; /读者编号记录data bro; data back; ReaderNode;typedefstructchar title15; char writer15; int current; int total; int key; /书的编号ReaderNode reader10; /记录借读该书的读者记录BookNode;typedefstructBookNode *elem; int count; /记录节点中的总
5、数HashTable;2. 算法流程图建立哈希表删除函数添加函数查找函数添加图书增量子函数借阅书子函数添加书子函数查看已添加书子函数归还书子函数查看已借阅书子函数查找书子函数主函数完成3. 程序代码*includestdaf*.h*include*include*include*include*include*define SUCCESS 1*define UNSUCCESS 0*define DUPLICATE -1*define NULL_KEY 0/无记录元素int hashsize=17,19,23,29;/存储容量int m=0;/表长typedef struct int year;
6、 int month; int day; data;typedef struct char num5; /读者编号记录 data bro; data back; ReaderNode;typedef struct char title15; char writer15; int current; int total; int key; int more;/书的编号 ReaderNode reader10; /记录借读该书的读者记录BookNode;typedef struct BookNode *elem; int count; /记录节点中的总数HashTable;void InitHash
7、Table(HashTable *H) int i; (*H).count=0; m=hashsize0; (*H).elem=(BookNode *)malloc(m*sizeof(BookNode); for(i=0;im;i+) (*H).elemi.key=NULL_KEY; unsigned Hash(int K)/哈希函数,自己设定 return K%m; void collision(int *p,int d) / 开放定址法处理冲突 *p=(*p+d)%m; int SearchHash(HashTable H,int K,int *p,int *c)/p为数据的地址位置,返回
8、 *p=Hash(K); while(H.elem*p.key != NULL_KEY & (K != H.elem*p.key) (*c)+; if(*cm) collision(p,*c); /下一地址 else break; if (K = H.elem*p.key) return SUCCESS; else return UNSUCCESS; int InsertHash(HashTable *H,BookNode e) int c,p; c=0; if(SearchHash(*H,e.key,&p,&c) return DUPLICATE; else if(chashsize0/2)
9、 (*H).elemp=e; +(*H).count; return 1; return 0;int DeleteHash(HashTable *H,BookNode e) int c,p; c=0; if(SearchHash(*H,e.key,&p,&c) (*H).elemp.key=NULL_KEY; -(*H).count; return 1; else printf(不好意思,不存在n); return 0;void AddBook(HashTable *H) BookNode e; int i; system(CLS); printf(nn*n); printf(t你能在此目录下
10、添加图书信息); printf(n*n); printf(nt 请输入书的编号(形如: 1*): ); scanf(%d,&e.key); getchar(); printf(nt 请输入书名: ); gets(e.title); printf(nt 请输入该书作者: ); gets(e.writer); printf(nt 请输入该书现库存量: ); scanf(%d,&e.current); printf(nt 请输入该书总库存量: ); scanf(%d%*c,&e.total); for(i=0;i10;i+) (e.readeri).num0=0; /用0来初始化借该书的读者证号,表
11、示一开始时没人借书 if(InsertHash(&(*H),e) printf(图书添加成功!n); (*H).count+; void ShowBook(HashTable H) int i; system(CLS); printf(nn*n); printf(t你能在此目录查看图书信息); printf(n*n); for(i=0;im;i+) if(H.elemi.key != NULL_KEY) /* 有数据 */ printf(图书%dn,H.elemi.key); printf(书名:%sn,H.elemi.title); printf(作者: %sn,H.elemi.writer
12、); printf(图书现存量: %dn,H.elemi.current); printf(图书总量: %dn,H.elemi.total); printf(*n); void BoSearch(HashTable *H)/借阅查询 int e,r,t; system(CLS); printf(nn*n); printf(t你能在此目录下按借书证号查找图书信息); printf(n*n); printf(nt 请输入你的借书证号: ); scanf(%d%*c,&e); if(SearchHash(*H,e,&r,&t) printf(借书证 %dn,(*H).eleme.key); prin
13、tf(书名:%sn,(*H).eleme.title); printf(作者: %sn,(*H).eleme.writer); printf(图书现存量:%dn,(*H).eleme.current); printf(图书总量:%dn,(*H).eleme.total); else printf(您没有借过书!);void Find(HashTable *H) int *,p,c; system(CLS); printf(nn*n); printf(t你能在此目录下按编号查找图书信息); printf(n*n); printf(nt 请输入你想查找的书的编号: ); scanf(%d%*c,&
14、*); if(SearchHash(*H,*,&p,&c) printf(图书%dn,(*H).elemp.key); printf(书名:%sn,(*H).elemp.title); printf(作者:%sn,(*H).elemp.writer); printf(图书现存量: %dn,(*H).elemp.current); printf(图书总量: %dn,(*H).elemp.total); else printf(对不起,不存在该书!n); void BorrowBook(HashTable *H) int i,k, *, f,t; system(CLS); printf(nn*n)
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构 课程设计 报告 图书 管理 系统 实验
链接地址:https://www.desk33.com/p-16769.html