




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、精选优质文档-倾情为你奉上数据结构课程设计图书管理系统一 需求分析该程序是模拟图书馆管理系统,实现图书采编入库、借书、还书、查询等基本业务。此程序规定:(1) 管理员能够向系统中输入每种书的基本信息,包括书号、书名、作者、现存量和库存量、借阅记录,并保存记录;(2) 用户(读者)能够按书号、书名、作者查询图书信息;(3) 管理员能够实现图书采编入库(新购入一本书,经分类和确定书号之后登记到图书账目中去。如果这种书在帐中已有,则只将总库存量增加)、借阅(如果书的现存量大于0,则借出一本,登记借阅者的图书证号和归还期限)、归还(删除对借阅者的登记,改变该书的现存量)、销毁(将图书从账目中删除)等操
2、作。二 概要设计l 系统用到的抽象数据类型定义: 1、ADT LinearList数据元素:D=ai|aiD0,i=1,2,n,n0,D0为某一数据对象关系:S=|ai,ai+1D0,i=1,2,n-1基本操作:(1) InitList(L)(2) DestroyList(L)(3) ClearList(L)(4) EmptyList(L)(5) ListLength(L)(6) Locate(L,e)(7) GetData(L,i)(8) InsList(L,i,e)(9) DelList(L,i,&e)ADT LinearList2、ADT String 数据对象:D=ai|aiChara
3、cterSet,i=1,2,n;n0 数据关系:R=|ai-1,aiD,i=2,n;n0 基本操作:(1) StrAsign(S,chars)(2) StrInsert(S,pos,T)(3) StrDelete(S,pos,len)(4) StrCopy(S,T)(5) StrEmpty(S)(6) StrCompare(S,T)(7) StrLength(S)(8) StrClear(S)(9) StrCat(S,T)(10)SubString(Sub,S,pos,len)(11)StrIndex(S,pos,T)(12)StrReplace(S,T,V)(13)StrDestroy(S)
4、ADT Stringl 系统中的子程序和功能说明:InitBo(Book &boo);初始化图书信息InitRe(lend &Lin);初始化借阅者信息BinarySearch(Book boo,char SearchNum);二分法查找比较书号Buy(Book &boo, char BuyNum);新书采编入库系统Delete(Book &boo,char DeleteNum);清除图书信息系统Borrow(Book &boo,lend &Lin,char BorrowNum,char CaNum);借阅图书处理系统Return(Book &boo,lend &Lin,char Return
5、Num,char BorrowerNum);归还图书系统SearchByNum(Book &boo,char SeaNum);按书号查找系统SearchByName(Book &boo);按书名查找系统SearchByAuth(Book &boo);按作者查询系统Menu();主菜单显示系统Search();查询系统子菜单main();主函数l 系统程序功能结构图图书馆管理系统图书信息录入查询图书信息处理图书信息基本信息借阅记录按书号查询按书名查询按作者查询图书采编入库图书借阅情况图书归还情况图书销毁情况三 详细设计l 功能实现过程bool BinarySearch(Book boo,char
6、 SearchNum) /二分法查找比较书号while(lowmid&total;i-)/*将新采购的书插在适合位置,保持有序*/ 空出插入位置; 输入新购书籍的相关信息:书号、书名、作者、出版社;booi.next=NULL;total+;/*总量加1*/void Delete(Book &boo,char DeleteNum)/*清除图书信息*/ if(书库中没有此书)输出“无此书”;if(书库中有此书) strcpy(连续两本书的相关信息);现存量减1;库存量减1;else 输出“此书已有借阅者,无法删除!”;void Borrow(Book &boo,lend &Lin,char Bo
7、rrowNum,char CaNum)/*借阅图书信息*/ if(没有找到此书) 输出“书库中无此书!”; if(书库中有此书) 借出一本书后,该书的现存量减1;并在借阅记录链表中插入该条记录;再对应读者信息记录链表,如果已有该读者证号信息,直接在该链表中插入此次借阅记录;如果无该读者证号信息,申请新单链表存放借阅记录。 else 输出“该书现存量为0”;void Return(Book &boo,lend &Lin,char ReturnNum,char BorrowerNum)/*归还图书信息*/ if(书库中无此书)输出“无此书记录”; if(书库中有此书) 查找图书文件,修改图书的现存
8、量;查找记录借阅信息的单链表,填入还书日期,删除借阅信息;查找记录读者信息的单链表,删除证号信息。void SearchByNum(Book &boo,char SeaNum)/*按书号查找*/ if(书库中无此书信息)/*用二分法查找*/ 输出“无此书”; else/*书库中有此书信息*/ 输出与此书有关的相关信息;void SearchByName(Book &boo)/*按书名查找*/输入想要查找书的书名;用顺序查找法查找;if(查找到需要查找的书) 输出与此书相关的信息;建议画出主要模块流程图。四 设计与调试分析1、这个程序设计中要注意定义两个结构体:图书结构体、借阅人结构体。其中定义
9、数组存放图书信息,申请链表存放借阅记录和读者信息记录。2、程序中运用到大多的插入与删除,所以申请链表比较方便插入与删除。但应前期需求分析的准备工作不充分,导致程序运行功能不全,比如查找时关于此书的信息不能全部显示出来,并且添加删除时库存的变化不能直接显示出来。程序的健壮性不能达到预期的结果,这些都是需要改进的。3、在程序中的函数调用是个非常重要的部分,也是经常需要用到的,在编写程序过程中,因为函数调用不准确,使得循环进不去,后来改变函数的调用关系,才达到了预期结果。4、程序中还定义了全局变量,之前没定义全局变量,在下面的编写过程,同样性质的地方需要重复定义,比较麻烦,定义全局变量使得程序比较简
10、明一点。五 用户手册【 使用说明 】1、进入图书馆管理系统主页面2、若有新书要新编入库,选择1,进入新书入库系统,输入入库书的书号,若书库中无该书,则设立新书目,输入新书信息。若书库中已有该书,则输入新信息覆盖修改原书库中该书号对应书的信息。3、若有书籍信息需要删除,选择2,进入清空库存系统,输入想要删除书的书号,则此书信息就已删除。4、若要借阅图书,选择3,进入图书借阅系统,输入需要借阅书的书号以及读者证号,并输入还书日期,则借书成功。5、若要归还图书,选择4,进入图书归还系统,输入需要归还图书的书号以及读者证号,则还书成功。6、若要查找信息,选择5,进入查找信息子系统。若要按书号查找,则选
11、择子系统中的1,输入需要查找的书的书号,若按书名查找,则选择子系统中的2,输入需要查找的书名,若按作者查找,输入需要查找书的作者进行查找,若查找结束,则按0退出。7、若系统使用结束,按0退出。【 程序中的头文件 】#include #include #include #define MAXSIZE 100 #define LIST_INIT_SIZE 100int Retotal;/*定义的全局变量*/int total;六 测试成果1、采编入库2、清空库存3、图书借阅4、图书归还5、图书查找七 附录(源程序清单)#include #include #include #define MAXSI
12、ZE 100 #define LIST_INIT_SIZE 100typedef struct Borochar BNum20; char RetDate8; struct Boro *next;Bor;typedef struct LinkBook Bor *next;char CNum20;int Total;lendLIST_INIT_SIZE;typedef struct LNodechar CardNum20;struct LNode *next;LinkList; typedef struct bookchar num20;char name20;char auth20;char
13、pub20;int TotNum;int NowNum;LinkList *next;BookMAXSIZE;int Retotal;int total; void InitBo(Book &boo) for(int i=0;iMAXSIZE;i+)booi.NowNum=0;booi.TotNum=0;booi.next=NULL;void InitRe(lend &Lin) for(int i=0;iLIST_INIT_SIZE;i+)Lini.next=NULL;int mid=0;bool BinarySearch(Book boo,char SearchNum) int low=0,
14、high=total;int found=0;while(lowmid&total;i-) booi=booi-1; printf(该书在书库中不存在,设立新书目!n);strcpy(booi.num,BuyNum);printf(该书购入的数量是:);scanf( %d,&booi.NowNum);booi.TotNum=booi.NowNum;printf(该书的名字是:);scanf( %s,&);printf(该书的作者是:);scanf( %s,&booi.auth);printf(该书的出版社是:);scanf( %s,&booi.pub);booi.next=N
15、ULL;total+;printf(已增加该书的信息!n);printf(编号 :%s 书名:%s ,booi.num,);printf(作者:%s 出版社:%s,booi.auth,booi.pub);printf(n);printf(入库成功.n);void Delete(Book &boo,char DeleteNum)if(BinarySearch(boo,DeleteNum)=false|total=0) printf(书库中没有该书.n);if(BinarySearch(boo,DeleteNum)if(!boomid.next)int j;for(j=mid;j
16、0) boomid.NowNum-;if(boomid.next=NULL) m=(LinkList *)malloc(sizeof(LNode);boomid.next=m;strcpy(m-CardNum,CaNum);m-next=NULL;else m=boomid.next;while(m-next) m=m-next;n=(LinkList *)malloc(sizeof(LNode);m-next=n;strcpy(n-CardNum,CaNum);n-next=NULL; int i=0;for(i=0;inext)p=p-next;q=(Bor *)malloc(sizeof
17、(Boro);p-next=q;strcpy(q-BNum,BorrowNum); printf(输入归还日期:);scanf(%s,&q-RetDate);q-next=NULL;printf(借阅成功.n);break; if(i=Retotal)strcpy(Lini.CNum,CaNum); p=(Bor *)malloc(sizeof(Boro);Lini.next=p;strcpy(p-BNum,BorrowNum);printf(输入归还日期:);scanf( %s,&p-RetDate);p-next=NULL;Retotal+; printf(借阅成功.n);else pri
18、ntf(借阅失败.该书现在库存为0.n);void Return(Book &boo,lend &Lin,char ReturnNum,char BorrowerNum)Bor *p,*q;LinkList *m,*n;int flag=0;if(!BinarySearch(boo,ReturnNum)|!total) printf(书库中无此书.n);if(BinarySearch(boo,ReturnNum) m=boomid.next;if(!strcmp(m-CardNum,BorrowerNum) boomid.NowNum+; boomid.next=m-next; free(m)
19、; elsewhile(m-next) if(!strcmp(m-next-CardNum,BorrowerNum) n=m-next; m-next=n-next; free(n); boomid.NowNum+; break;m=m-next;for(int i=0;iBNum,ReturnNum) Lini.next=p-next; free(p); printf(成功归还该书.n);flag=1;break;else while(p-next) if(!strcmp(p-next-BNum,ReturnNum) q=p-next; p-next=q-next; free(q); pri
20、ntf(成功归还该书.n);flag=1;break;p=p-next;for(int k=0;kRetotal;k+)if(!Link.next)int j;for(j=k;jRetotal;j+)Linj=Linj+1; strcpy(Linj.CNum, ); Retotal-; if(flag=0) printf(无该证信息.n);void SearchByNum(Book &boo,char SeaNum)LinkList *p;p=boomid.next;if(BinarySearch(boo,SeaNum)=true)printf(书号:%sn,boomid.num);print
21、f(书名:%sn,);printf(作者名:%sn,boomid.auth);printf(出版社:%sn,boomid.pub);printf(现存量:%sn,boomid.NowNum);printf(库存量:%sn,boomid.TotNum);printf( n);elseprintf(对不起,未找到您想查找的书。n);void SearchByName(Book &boo)char SeaName20;printf(输入想查找的书的书名:n);scanf( %s,&SeaName);printf(此书存在!n);for(int i=0;itotal;i+)if(
22、strcmp(SeaName,)=0)printf(编号:%s 书名:%s ,booi.num,);printf(作者:%s 出版社:%s,booi.auth,booi.pub);printf(总库存量:%s,booi.TotNum);printf(现库存量:%s,booi.NowNum);printf(n);void SearchByAuth(Book &boo)char SeaAuth20;printf(输入想查找的书的作者:n);scanf( %s,&SeaAuth);printf(找到符合该作者的书的详细信息如下:n);for(int i=0;ito
23、tal;i+)if(strcmp(SeaAuth,booi.auth)=0) printf(编号 :%s 书名:%s ,booi.num,); printf(作者:%s 出版社:%s,booi.auth,booi.pub); printf(n);void Menu() printf( 图书馆管理系统 n);printf(1. 采编入库 2. 清空库存nn);printf(3. 图书借阅 4、图书归还nn); printf(5. 按要求查找 0. 退出nn); printf(请选择:);void Search()char BNum20;Book Bo;int k;printf( 图书馆查询子系统n);printf(1、按书号查询 2、按书名查找nn);printf(3、按作者查询 4、退出子系统nn);printf(请选择:);scanf(%d,&k);switch(k)case 1:printf(请输入书号:);/输入书号查找scanf( %s,&BNum);S
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年贵州工程职业学院单招职业倾向性测试题库完美版
- 电子商务平台的支付系统分析与优化
- 走向整体的世界课件-2024-2025学年高一下学期统编版(2019)必修中外历史纲要下
- 2025年河南轻工职业学院单招职业适应性测试题库附答案
- 2025年吉林省吉林市单招职业适应性测试题库审定版
- 2025年广西制造工程职业技术学院单招职业技能测试题库附答案
- 科技改变生活农村地区的生活变化与展望
- 科技与网络文化的融合发展
- 2025年广西培贤国际职业学院单招职业技能测试题库及答案一套
- 2025年广东省江门市单招职业倾向性测试题库一套
- 三方公司合作协议书范本
- 护理责任组长续聘竞聘
- 2024-2025学年第二学期教学教研工作安排表
- 2025年贵州云上产业服务有限公司招聘笔试参考题库含答案解析
- 2025年南京信息职业技术学院高职单招职业适应性测试近5年常考版参考题库含答案解析
- 2025-2030年中国天然气行业发展分析及发展趋势预测报告
- 《雷达信号处理基础》课件
- 2025届贵州省兴义市三年级数学第一学期期末达标检测试题含解析
- 人教版地理七年级下册7.1.2 亚洲的自然环境(课件39张)
- 外研版(三起)小学英语三年级下册Unit 1 Animal friends Get ready start up 课件
- 2025年交通运输部广州打捞局招聘事业编制人员13人历年管理单位笔试遴选500模拟题附带答案详解
评论
0/150
提交评论