ImageVerifierCode 换一换
格式:DOCX , 页数:26 ,大小:1.13MB ,
资源ID:5575395      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/5575395.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(图书馆管理系统程序.docx)为本站会员(b****6)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

图书馆管理系统程序.docx

1、图书馆管理系统程序程序设计实践报告学号;题目来源及序号难度等级 一、题目说明:由教师给出题目13、 图书管理系统(查找应用)问题描述图书管理基本业务活动包括:对一本书的采编入库、清除库存、借阅和归还等等。试设计一个图书管理系统,将上述业务活动借助于计算机系统完成。实现提示1、 每种书的登记内容至少包括书号、书名、著者、现存量和总库存量等五项。2、 由于图书管理的基本业务活动都是通过书号(即关键字)进行的,所以要用对书号 索引,以获得高效率。3、 系统应实现的基本功能有:4 采编入库:新购入一种书,经分类和确定书号之后登记到图书帐目中去。如果这两种书在帐中已有,则只将总库存量增加。5 清除库存:

2、某种书已无保留价值,将它从图书帐目中注销。6 借阅:如果一种书的现存量大于零,则借出一本,登记借阅者的图书证号和归还期限。7 归还:注销对借阅者的登记,改变该书的现存量。8 显示:以凹入表的形式显示B树。这个操作是为了调试和维护的目的而设置的。二、问题分析及求解基本思路说明:给出题目的分析及初步的解题思路。要求简洁、易懂一、概要设计主要实现系统的功能:a.图书初始化: 输入图书的一些信息,编号、作者、书名、数量,有一定的库存。b.新书入库: 新书采编入库,输入编号后有次数只需输入数量,没有则继续输入c.添加读者信息: 读者信息初始化,输入读书证号和姓名后才能进行借书还书d.借书模块: 读者输入

3、读书证号,证号存在输入要借的图书编号,不能借同一本书,如果借书数量以达到最大也不能借书。e.还书模块: 归还已借的图书,要先输入读者书证号,书证号存在继续输入要还的图书编号,图书编号存在并且借来此书,归还成功。f.查询图书信息g.查询读者信息: 可查询读者姓名书证号,借了几本书,都是什么书和还书日期, 还可以借几本书。 h.退出: 退出读书管理系统并保存读者和图书信息。 设计的的初步思路:主要采取定义结构体,定义两个结构体分别为图书结构体和阅读者的结构体,将其数据存储到字符串中,然后逐个构建单链表,将其数据存储到单链表结点的数据域中,然后进行图书文件的读取或者可以选择图书的初始化,输入图书的编

4、号,作者,书名,数量和一定的库存和现存量。新书入库创造新结点,定义指针,此处分两种情况,若图书编号存在,则直接进库,只须输入书的数量,通过字符串的比较来判定,同理阅读者的添加是增加阅读者的单链表的结点,同时一个读者规定只能借阅5本书存储到数据域的字符串中。分别定义还书和借书的函数,用字符串的比较功能判断读者借书不能同一种书借两次,同时采编新书要求如果书号相同只需要直接输入采编的本数和如果没有书时会返回等待新书到来,包括索书号以及读者的学号输入出现不存在会返回错误,还书函数也是通过字符串中存储的库存量和现存量增加,同时读者借书数量right减少。最后将图书的单链表和阅读者的单链表读写到文件中。三

5、、问题求解的整体框架结构说明:围绕求解目标给出具体的模块。要求简洁、易懂1图书录入流程图: 2登记读者程图: N N Y Y3增添图书录入流程图: N Y Y N 4还书管理流程图: N YN Y打印读者图书信息:结束四、主要算法说明:要求用自然语言描述算法。要求简洁、易懂(1)首先首先定义图书,阅读者,借书结构体;typedef struct book;typedef struct borrow;typedef struct reader;定义好各种说需要的数据:typedef struct book char book_num10;/图书编号 char book_name20;/图书名称

6、char book_writer10;/图书的作者 int book_xy;/现有量 int book_kc;/库存 struct book *next;BK;typedef struct borrowchar borrow_book_num10;/借书的总数char limit_date8;/还书日期BO;typedef struct readerchar reader_num10;char reader_name10;int right;/读者所借的书的本数BO borrowMax;struct reader *next;RD;(1)定义实现功能所需要的函数,包括图书的登记,读者的登记,图

7、书的录用,以及读者的借阅,图书,读者信息的保存和读音等功能。int Menu(); void Init();void Login(); void Init_book();void Insert_New_Book(); void Menu_select(); void Find_Book(); void add_reader();void Print_reader(); void Print_book(); void Borrow_Book(); void Return_Book(); void Save(); void Save_Book(); void Save_Reader(); void

8、 Load();void Load_Reader(); void Load_Book();void Login()(3)通过字符串存储读者和图书的信息,然后进行图书文件的读取或者可以选择图书的初始化,输入图书的编号,作者,书名,数量和一定的库存和现存量。新书入库创造新结点,定义指针,此处分两种情况,若图书编号存在,则直接进库,只须输入书的数量,通过字符串的比较来判定,同理阅读者的添加是增加阅读者的单链表的结点,同时一个读者规定只能借阅5本书存储到数据域的字符串中。分别定义还书和借书的函数,用字符串的比较功能判断读者借书不能同一种书借两次,同时采编新书要求如果书号相同只需要直接输入采编的本数和如

9、果没有书时会返回等待新书到来,包括索书号以及读者的学号输入出现不存在会返回错误,还书函数也是通过字符串中存储的库存量和现存量增加,同时读者借书数量right减少。最后将图书的单链表和阅读者的单链表读写到文件中。void Insert_New_Book()/*新书入库*/ BK *p,*p0,*p1; p=p1=h_book;printf(n新书入库模块.n);printf(n请输入图书信息.n包括书号.书名.数量.n);p0=(BK *)malloc(sizeof(BK); printf(图书编号:); scanf(%s,p0-book_num); while(strcmp(p0-book_n

10、um,p1-book_num)!=0&p1-next!=NULL) p1=p1-next; if(strcmp(p0-book_num,p1-book_num)=0) /*此处分两种情况,若图书编号存在,则直接进库,只须输入书的数量*/ printf(n此编号图书已存在!直接入库!n); printf(图书数量:); scanf(%d,&p0-book_kc); p1-book_kc+=p0-book_kc; p1-book_xy+=p0-book_kc; else printf(图书名称:); scanf(%s,p0-book_name); printf(图书作者:); scanf(%s,p

11、0-book_writer); printf(图书数量:); scanf(%d,&p0-book_kc);/库存数量while(p-next) p=p-next; if(h_book=NULL) h_book=p0; else p-next=p0; p0-next=NULL; p0-book_xy=p0-book_kc; printf(n新书入库完毕!按任意键继续下一步操作.n); getch(); system(cls); void add_reader()/*添加读者*/ RD *p0; int i; printf(n读者初始化开始,请输入读者信息.n包括书证号.姓名.n);p0=(RD*

12、)malloc(sizeof(RD); h_reader=p0;printf(n请输入读者的信息:n); printf(读者书证号:); scanf(%s,p0-reader_num); printf(读者姓名:); scanf(%s,p0-reader_name); p0-right=0; for(i=0;iborrowi.borrow_book_num,0); strcpy(p0-borrowi.limit_date,0); p0-next=NULL; printf(n读者信息初始化完毕!按任意键继续下一步操作.n); getch(); system(cls); void Borrow_B

13、ook() /*借书模块*/ BK *p0; RD *p1;char bo_num10,rea_num10,lim_date8;int i;p0=h_book; p1=h_reader;printf(n借书模块.n);printf(n请输入借书的读者书证号:); scanf(%s,rea_num);while(p1-next!=NULL&strcmp(rea_num,p1-reader_num)!=0) p1=p1-next; if(p1-next=NULL&strcmp(rea_num,p1-reader_num)!=0) printf(n此读者编号不存在!按任意键返回.n); goto E

14、ND; printf(n请输入你要借的书的编号:); scanf(%s,bo_num); while(strcmp(bo_num,p0-book_num)!=0&p0-next!=NULL) p0=p0-next; if(p0-next=NULL&strcmp(bo_num,p0-book_num)!=0) printf(n此图书编号不存在!按任意键返回.n); goto END; else if(p0-book_xyrightMax|p1-right=Max) printf(n不好意思,借书数目已满!不能借书!n按任意键返回.); goto END; else if(strcmp(p1-bo

15、rrow0.borrow_book_num,0)!=0) for(i=0;iborrowi.borrow_book_num,bo_num)=0) printf(n抱歉!同一读者不能同借两本相同的书!n按任意键返回.); goto END; else if(strcmp(p1-borrowi.borrow_book_num,0)=0) printf(n请输入你要归还图书的日期:); scanf(%s,lim_date); strcpy(p1-borrowp1-right+.borrow_book_num,bo_num); strcpy(p1-borrowp1-right-1.limit_date

16、,lim_date); p0-book_xy-; p0-book_kc-; printf(n读者编号%s借书完毕!按任意键继续下步操作.,p1-reader_num); goto END; else printf(n请输入你要归还图书的日期:); scanf(%s,lim_date); strcpy(p1-borrowp1-right+.borrow_book_num,bo_num); strcpy(p1-borrowp1-right-1.limit_date ,lim_date ); p0-book_xy-; p0-book_kc-; printf(n读者编号%s借书完毕!按任意键继续下步操

17、作.,p1-reader_num); END:getch(); system(cls); void Return_Book() /*还书模块*/ BK *p; RD *q;int i,j,find=0;char return_book_num10,return_reader_num10;p=h_book; q=h_reader;printf(n还书模块.n);printf(n请输入要还书的读者编号:); scanf(%s,return_reader_num); while(q-next!=NULL&strcmp(return_reader_num,q-reader_num)!=0) q=q-n

18、ext;if(q-next=NULL&strcmp(return_reader_num,q-reader_num)!=0) find=2; printf(n此读者编号不存在!按任意键返回.n); goto end; printf(n请输入读者还书的编号:); scanf(%s,return_book_num); while(p-next!=NULL&strcmp(return_book_num,p-book_num)!=0) p=p-next; if(p-next=NULL&strcmp(return_book_num,p-book_num)!=0) find=2; printf(n错误!此图

19、书编号不存在!按任意键返回.n); goto end; for(i=0;iborrowi.borrow_book_num)=0) /*如果此读者借了此书*/ find=1; for(j=i;jborrowj.borrow_book_num,q-borrowj+1.borrow_book_num); strcpy(q-borrowj.limit_date,q-borrowj+1.limit_date); strcpy(q-borrowMax-1.borrow_book_num,0); strcpy(q-borrowMax-1.limit_date,0); p-book_xy+; p-book_k

20、c+; q-right-; printf(n编号%s的读者已完毕!按任意键继续下步操作.,return_reader_num); if(find=0) printf(n错误!此读者未借此书!按任意键返回.n); end: getch(); system(cls);void Print_book() /*查询图书信息*/BK *p;p=h_book;printf(n图书信息如下:nn);printf(图书编号t图书名称t图书作者t现有tt库存n); while(p!=NULL) printf(%stt%stt%stt%dtt%dn,p-book_num,p-book_name,p-book_wr

21、iter,p-book_xy,p-book_kc); p=p-next;printf(n图书信息打印完毕!按任意键继续下一步操作.);getch();system(cls);void Print_reader() /*查询读者信息*/RD *p;int i;p=h_reader;printf(n读者信息如下:nn);printf(读者书证号tt读者姓名n); printf(n);while(p!=NULL) printf(t%stt%s,p-reader_num,p-reader_name); for(i=0;iborrowi.borrow_book_num); printf(tt%s,p-b

22、orrowi.limit_date); printf(n); p=p-next;printf(n读者信息打印完毕!按任意键继续下一步操作.);getch();system(cls);void Save() /*保存信息*/Save_Reader();Save_Book();void Save_Reader() /*保存读者信息*/(2)通过创建文件将图书和读者的单链表和图书的单链表输入到文件里,再读取文件,关闭文件。FILE *fp_reader; RD *p,*p0;p=h_reader;if(fp_reader=fopen(Reader.txt,wb)=NULL) /*创建文件,进行保存*

23、/ printf(n文件保存失败!n请重新启动本系统.n); exit(0);while(p!=NULL) if(fwrite(p,sizeof(RD),1,fp_reader)!=1) /*将链表中的信息写入文件中*/ printf(n写入文件失败!n请重新启动本系统!n); p0=p; p=p-next; free(p0); /*释放所有结点*/h_reader=NULL;fclose(fp_reader); void Save_Book() /*保存图书信息*/FILE *fp_book; /*创建文件型指针*/BK *p,*p0;p=h_book;if(fp_book=fopen(Bo

24、ok.txt,wb)=NULL) /*创建文件,进行保存*/ printf(n文件保存失败!n请重新启动本系统.n); exit(0);while(p!=NULL) if(fwrite(p,sizeof(BK),1,fp_book)!=1) /*将链表中的信息写入文件中*/ printf(n写入文件失败!n请重新启动本系统!n); p0=p; p=p-next; free(p0); h_book=NULL;fclose(fp_book); void Load() /*加载信息*/Load_Reader();Load_Book();void Load_Reader() /*加载读者信息*/ RD

25、 *p1,*p2,*p3; FILE *fp; /*创建文件型指针*/ fp=fopen(book.txt,rb); /*打开文件*/ p1=(RD *)malloc(sizeof(RD); fread(p1,sizeof(RD),1,fp); h_reader=p3=p2=p1; while(! feof(fp) /*读出信息,重新链入链表*/ p1=(RD *)malloc(sizeof(RD); fread(p1,sizeof(RD),1,fp); p2-next=p1;p3=p2; p2=p1; p3-next=NULL; free(p1); fclose(fp); void Load

26、_Book() /*加载图书信息*/BK *p1,*p2,*p3;FILE *fp; /*创建文件型指针*/fp=fopen(Book.txt,rb); /*打开文件*/ p1=(BK *)malloc(sizeof(BK); fread(p1,sizeof(BK),1,fp); h_book=p3=p2=p1; while(! feof(fp) /*读出信息,重新链入链表*/ p1=(BK *)malloc(sizeof(BK); fread(p1,sizeof(BK),1,fp); p2-next=p1; p3=p2; p2=p1; p3-next=NULL; free(p1); fclo

27、se(fp); 5编写主函数,执行程序。void main() FILE *fp_book,*fp_reader; Login(); if(fp_book=fopen(Book.txt,rb)=NULL|(fp_reader=fopen(Reader.txt,rb)=NULL) Init(); else Load(); Menu_select(); 五、测试说明:细致测试。1)登入系统,进行文件初始化。2)进入主菜单,开始实现功能。3)选择功能1,输入采编图书信息。4)选择2,登记读者。5)执行3,开始借阅图书,输入借书编号,读者编号,以及还书日期。6)执行6,查询图书信息,发现图书的减少量,库存和预存。7)登记图书,采编新书,如果图书已存在,则直接输入数量。8)还书模块4,输入读者及图书的信息。9)执行5,查询读者信息。10)再查询图书信息,发现还书后,图书现有量改变。11)同一读者不能借同一种书两本。12)如果图书为零,则说明书库

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1