




已阅读5页,还剩3页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
/quanxunwang/“程序设计专周”报告实验题目: 模拟图书馆管理系统 班 级: 学 号: 33号 姓 名: 指导教师: 日 期: 19周一 周五 一、题目:模拟图书馆管理系统 模拟图书管理系统:图书管理的基本业务包括对一本书的入库、清除、查询、借出、归还等,设书的内容至少包括书号、书名、作者、库存总量和现存量等。二、算法基本思想描述: 将整个程序划分为五个模块,分别定义了五个函数来实现管理系统的功能,采用单链表的结构进行数据操作。三、设计数据结构的设计typedef struct BookList char num10; char name20; char author20; int total; int leavings; struct BookList *next;Book; 采用链表的结构来进行数据操作,一本书的数据包括:书号、书名、作者、库存总量、现存量以及指针区域。算法的设计()关键算法设计思路描述 在构思图书馆管理系统的结构时,我将整个程序划分为五个模块,分别定义了五个函数来实现管理系统的功能,除此之外在对程序的界面设计上加入了一些动画效果。在数据结构上采用单链表的结构方式,这样在读取文件中数据的时候能够节省内存空间。设计主菜单时,用while(1)和switch()来实现功能的选择以及运行一项功能后返回主菜单。在整个程序中,统一采用了以输入的方式返回或退出,并在模块有需要键盘输入地方加入了防错误输入的功能,防止输入错误导致程序错误运行,此功能采用判断输入值的ASCII码或字符串的比较。入库模块:首先判断数据文件是否存在,如存在以追加的方式打开,如不存在以写入的方式打开。输入图书的具体数据(在输入过程中,如输入的书号为则返回主菜单)、存盘,判断存盘成功则打印“成功添加”,如存盘失败打印“添加失败”。最后返回入起始界面(入库模块)。清除模块:进入清除模块则将文件中的全部数据用单链表的结构读入内存,提示输入要删除的书号,在内存中寻找并删除,删除后可以马上存盘或是直到全部删除完成后再选择操作,在防止操作后忘记存盘,在程序中加入了自动判断操作过的数据是否己经进行过存盘的功能。查询模块:本模块分为三个子模块:以书号方式查询、以书名的方式查询、以作者的方式查询。前两个查询功能只要找到符合条件的数据时就停止,以作者方式因为考虑到一个作者不止一本作品,所以对全部的数据进行查找,并打印出所有符合条件的数据。如果未找到则打印“没有找到”,最后返回子功能模块起始,直到输入返回上一级。借出、还书模块:这两个功能的思路完全一样,不同的是对数据中的现存量的运算。两个功能都是先建立一个图书类型的数据指针,逐条将文件中的数据读入内存,并与输入的数据进行比较,如果一致则先对内存中的数据进行操作,再将文件中的fp指针后退sizeof(Book)个字节,将内存中的经过修改过的数据写入文件。完成一条操作后,提示进行下一条操作,输入时返回主菜单。()程序结构及模块名称描述主程序界面初始化入 库清 除查 询借 出归 还书号 查询书名 查询作者 查询全部 列表a ) void main() /主程序b ) void s(long) /时间延迟函数c ) void sta() /界面初始效果d ) void wel() /界面初始效果e ) void bookadd()/入库f ) void sa_ve(sqtype) /清除函数中保存文件函数g ) void del() /清除h ) void r() /查询j ) void s_1() /查询功能中以书号方式查询k ) void s_2() /以书名方式查询l ) void s_3() /以作者方式查询m ) void readall() /列出全部图书n ) void borrow() /借出o ) void back() /归还p ) void bye() /退出效果()主要模块算法描述/*添加*/void bookadd() /*添加图书*/ FILE *fp; Book finger; char temp10; fp=fopen(blist.db,rb);/*读方式打开文件*/ if(fp=NULL) fp=fopen(blist.db,wb); /*写方式打开文件*/ else/*如果有书就添加*/ fclose(fp); fp=fopen(blist.db,ab);/*追加方式打开文件*/ clrscr(); while(1) printf(n请输入数据:n);/*逐个输入新图书的资料*/ printf(请输入书号(输入0结束添加):); gets(temp); if(strcmp(temp,0) strcpy(finger.num,temp); else break; printf(请输入书名: ); scanf(%s,); printf(请输入书的作者: ); scanf(%s,finger.author); printf(请输入书的总数: ); scanf(%d,&finger.total);b=getchar(); finger.leavings=finger.total; finger.next=NULL; if(fwrite(&finger,sizeof(Book),1,fp)/*块写*/ printf(-n); printf(己成功添加:n书号:%s 书名:%s 作者:%s 库存总量:%d 现存量:%dn,finger.num,,finger.author,finger.total,finger.leavings); printf(-); else printf(对不起,数据写入文件错误!); fclose(fp); clrscr();/*删除*/del() /*删除功能函数*/ FILE *fp;Book *head,*p,*q,*temp;char a10,s;int flag=0,flag2,flag3=0; fp=fopen(blist.db,rb); head=p=q=(Book*)malloc(sizeof(Book); fread(p,sizeof(Book),1,fp); while(!feof(fp) q=p; p=(Book*)malloc(sizeof(Book); fread(p,sizeof(Book),1,fp); q-next=p; p-next=NULL;del_re: flag2=0; clrscr(); gotoxy(1,3);textcolor(4);cprintf(提示:); textcolor(7);gotoxy(6,4);printf(您可以逐次操作后存盘,也可以完成全部); gotoxy(6,5);printf(操作后退出时存盘,不进行存盘您所有删);gotoxy(6,6);printf(除操作对文件无效!); gotoxy(1,23);printf(请输入要删除的书号(0退出,00存盘):);gets(a); if(!strcmp(a,0) goto del_end; else if(!strcmp(a,00) if(flag=0) gotoxy(50,24);textcolor(4);cprintf(您还未进行任何删除操作!);textcolor(7);getch();clreol();goto del_re; else flag3+=sa_ve(head);goto del_re; p=head; while(p!=q-next) if(!strcmp(a,p-num) if(p=head) head=p-next;flag+;flag2=1;gotoxy(35,13);printf(删除成功!);getch();goto del_re; else temp-next=p-next;flag+;flag2=1;gotoxy(35,13);printf(删除成功!);getch();goto del_re; temp=p; p=p-next; if(flag2=0) gotoxy(50,24);textcolor(4);cprintf(对不起没有找到你要删除的数据!);textcolor(7);getch();clreol();goto del_re;del_end: if(flagflag3) gotoxy(22,13);clreol();printf(您还有删除操作未存盘,是否存盘(Y/N):);s=getchar(); if(s=78|s=89|s=110|s=121) if(s=89|s=121) gotoxy(1,13);clreol();sa_ve(head);b=getchar(); else b=getchar();goto del_end2; else goto del_end; del_end2: fclose(fp);/*查找(按书号查找)*/s_1() /*查找子函数中的按书号查询功能*/ char temp_num10; Book finger; int flag; FILE *fp; fp=fopen(blist.db,rb);s_1re: flag=0;gotoxy(1,25);printf(请输入书号(输入0返回):); scanf(%s,temp_num); if(!strcmp(temp_num,0) fclose(fp);goto s_1end; while(!feof(fp) fread(&finger,sizeof(Book),1,fp); if(!strcmp(finger.num,temp_num) clrscr(); textcolor(4);cprintf( 书号);gotoxy(17,1);cprintf(书名); gotoxy(33,1);cprintf(作者);gotoxy(47,1);cprintf(总库存); gotoxy(63,1);cprintf(现存量rn);textcolor(7); printf( %stt%stt%stt%dtt%dn,finger.num,,finger.author,finger.total,finger.leavings); flag=1;rewind(fp);break; if(flag=0) clrscr();gotoxy(28,12);printf(没有找到您要查询的书!);rewind(fp);getch();clrscr(); goto s_1re;s_1end: b=getchar();/*借书功能*/borrow() FILE *fp;char a10;int flag; Book n; fp=fopen(blist.db,rb+); clrscr();borrow_re: flag=0; gotoxy(1,13);clreol();gotoxy(1,24); clreol(); gotoxy(1,23);printf(请输入要借的书号(输入0返回):);clreol(); gets(a);if(!strcmp(a,0) goto borrow_end; fread(&n,sizeof(Book),1,fp); while(!feof(fp) if(!strcmp(a,n.num) /*一样的话*/ if(n.leavings=0) printf(对不起,此书全部借出.n); else -n.leavings; fseek(fp,-56L,1); fwrite(&n,sizeof(Book),1,fp); gotoxy(35,13);printf(借出成功!);flag=1;getch(); rewind(fp);break; fread(&n,sizeof(Book),1,fp); if(flag=0) gotoxy(35,13);printf(借书失败!);rewind(fp);getch(); goto borrow_re;borrow_end: fclose(fp); 四、源程序清单:(见源程序文件名:_lib.c_)五、测试数据及测试结果:(一)添加输入数据:书号 书名 作者 库存1001 h1 li 81002 h2 ki 81003 h3 fd 91004 h4 li 101005 h5 sdfs 111006 h6 ed 91007 h7 tio 7(二)清除输入清除的书号:1006提示删除成功,运行查询功能中的查询全部功能,确认1006己被删除(三)查询书号查询,输入:1005输出:1005 h5 sdfs 11书名查询,输入:h7输出:1007 h7 tio 7作者查询,输入:li输出:1001 h1 li 8 1004 h4 li 10(四)借出输入:1004输出:借出成功运行查询功能中的查询全部功能,显示:书号书名作者库存现存1004 h4 li 10 9(五)归还输入:输出:归还成功运行查询功能中查询全部,显示:书号书名作者库存现存1004 h4 li 10 10六、心得体会:编写整个模拟图书馆管理程序历时五天,五个功能模块中的入库与查询模块由于定义函数名与语言中自带函数名冲突,到发现原因并修改,期间耗时三天。在三天期间,在不知道冲突原因之前,我在几个论坛上发贴,有回贴的竟没人知道原因,后来偶然的灵机一动,将函数名更改,程序顺利运行。我还从网上下了一本语言函数的电子书,经查确实是由于函数名冲突。所以,我们在定义函数的时候,在注意函数名是否与语言自带的函数冲突。因为我比较喜欢有应用性的程序,所以挑选图书馆来做,但是在确定所用数据结构方面,构思时考虑不足,忽略了图书馆内书的数据量,一直到入库与查询两个模块完成,我还是采用顺序表的结构来进行数据操作,但是在编写清除模块的时候,突然间发现将文件数据全部读出时,如果采用顺序链表就必须欲先定制一个足够大的空间,所以我又将数据结构改成单链表以节省内存空间。在编写入库和查询模块时,用的知识都只是大一所学语言老师教过的,如打开文件fopen命令,读取文件fread命令,写入文件fwrite命令等等。对文件的其它详细操作一无所知,如读取时文件fp指针的位置,如何让fp指针在文件中定位等等。但是我在编写借出,归还和清除三个模块时,恰恰得用到这些知识,所以借用ftell()命令,自己慢慢的摸索出一些门道。如:在借出和归还模块里,我采用的方法是,定义一个图书类型的结构体指针,一次从文件里只读取一个数据,将它的关键字符段与输入数据进行比较,如果一致则将文件指针fp往后移动sizeof(Listtype)个字节,然后将经过这个修改后的数据写入文件。之所以采用这个方法,我是考虑到它在内存中只占用了sizeof(Listtype)字节个空间,并且也只需向文件中写入一次。如果用链表全部读取、修改后再保存文件,一是占用了很大的内存空间,二是要向文件中写入全部的数据。但
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025浙江舟山市普陀区妇幼健康服务中心招聘编外人员1人考试模拟试题及答案解析
- 2025云南黄金集团第二次招聘工作人员8人笔试备考题库及答案解析
- 2025安徽合肥凯欣教育集团招聘2人考试参考题库附答案解析
- 2025云南楚雄州武定县插甸学校教师招考13人流动考试备考试题及答案解析
- 2025浙江绍兴市人防工程质量安全和技术服务中心编外用工招聘1人笔试参考题库附答案解析
- 2025贵州贵阳市某机关工作人员招聘笔试参考题库附答案解析
- 2025浙江金华市金西丰子恺学校(汤溪中学委托管理)招聘储备教师4人考试参考题库附答案解析
- 2025安徽长丰县北城世纪城学校临聘教师招聘24人笔试模拟试题及答案解析
- 甘南事业单位2025年招聘笔试参考题库附答案解析
- 2025年秋宣恩县城区学校公开选聘71名县内在编教师考试参考题库附答案解析
- 2025年秋季学期(统编版)二年级上册语文教学工作计划及教学进度表
- 2025年福建省厦门市【辅警协警】笔试真题(含答案)
- (2025年标准)委托他人要账协议书
- 2025-2030中国青少年无人机教育课程体系构建与创新能力培养研究
- 2025年金融消费者权益保护考试题与答案
- 煤矿安全规程新旧版本对照表格版
- 2025山东“才聚齐鲁成就未来”水发集团高校毕业招聘241人笔试参考题库附带答案详解(10套)
- 中学2025年秋季第一学期开学工作方案
- 儿童急救流程
- GB 11122-2025柴油机油
- 私募薪酬管理办法
评论
0/150
提交评论