图书信息管理系统(共19页).doc

上传人:飞****2 文档编号:13369687 上传时间:2022-04-29 格式:DOC 页数:19 大小:167KB
返回 下载 相关 举报
图书信息管理系统(共19页).doc_第1页
第1页 / 共19页
图书信息管理系统(共19页).doc_第2页
第2页 / 共19页
点击查看更多>>
资源描述

《图书信息管理系统(共19页).doc》由会员分享,可在线阅读,更多相关《图书信息管理系统(共19页).doc(19页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、精选优质文档-倾情为你奉上本系统结构简单,功能不多,供初学者参考使用!需求分析我所设计的系统主要包括学生登陆模块和管理员登陆模块,并设置了简单的权限处理(只有帐号和密码全都正确时方能进入系统)。但并未尽善尽美,有些地方存在漏洞,主要内容及功能如下:学生登录模块:1.图书查询(包括对书名,作者,分类号(即是编号),出版社,出版时间,价格,总库存量及现库存量的查询)。2.图书排序(可对各个图书信息的项目进行从小到大排序)。3.浏览全部图书(输出全部图书信息)4.借书系统(每人只可借一本书)5.还书系统6.修改密码(查看密码是否修改成功时,需要进入查看个人资料,用新密码进入)7.查看个人资料(图书名

2、与分类号初始为0,意味着尚未借阅任何图书)管理员登陆系统:1.图书查询2.图书排序3.浏览全部图书4.添加图书信息(可逐个添加,也可批量添加)5.删除图书信息(输入时,需要输入图书的分类号)6.修改图书信息(可修改图书名,作者名等相关图书信息)头函数名:#include#include#includevoid welcome();/欢迎用户使用int denglu1(struct student s,int i);/学生登陆int denglu2();/管理员登陆struct book * creatbook();/创建链表,将文件中的图书信息写入链表int inputchoice();/选择

3、菜单int inputchoice1();/学生选择菜单int inputchoice2();/管理员选择菜单void pmenu(struct book * head);/学生主功能选择菜单void menu2(struct book * head);/管理员主功能选择菜单struct book * addbook(struct book * head);/添加图书信息int chashu(struct book *head,char m20);/查找分类号是否存在struct book *insert1(struct book * head,struct book *p);/增加接点voi

4、d printbook(struct book * head);/图书查找int putchoice();/选择查找内容void chaname1(struct book * head);/按书名查找void chaprice(struct book * head);/按价格查找void chacnum(struct book * head);/按分类号查找void chazuozhe(struct book * head);/按作者名查询图书信息void chatime(struct book * head);/按出版时间查找void chapress(struct book * head)

5、;/按出版社查找void sortbook(struct book * head);/排序选择void shuming(struct book * head);/按图书名排void ptime(struct book * head);/按出版时间排序void price1(struct book * head);/按图书价格排void fenleihao(struct book * head);/按图书编号排序void zuo1(struct book * head);/按作者名排序void pre1(struct book * head);/按出版社排序struct book * shanc

6、hubook(struct book * head);/删除图书信息void fprint(struct book * head);/将新链表写入文件中void xiugai(struct book * head);/修改图书信息void printbook1(struct book * head);/浏览全部图书信息int chacun(struct book * head,char m20);/查找库存量是否为0int jige();/求出文件中客户的个数int xcz(struct book * head,char cnum20);/把库内图书的库存量减一int xcz1(struct

7、book * head,char cnum20);/把库内图书的库存量加一void backbook(struct student s,int i,struct book * head);/还书函数void borrowbook(struct student s,int i,struct book * head);/借书函数void xmima(struct student s,int i);/修改密码void xwj(struct student s,int i);/将修改后的数组写入文件void oneself(struct student s,int i);/查看个人信息int jie(

8、char cnum20,int i,struct student s,char mnum20);/查询是否借书int huan(int i,struct student s,char mnum20);/借书查询是否借书图书信息结构体:struct bookchar bookname20;/书名char ename20;/作者char cnum20;/图书分类号即图书编号,区别其余图书唯一特征char pubpress20;/出版社char pubtime20;/出版时间int price;/价格 int zc;/现库存int xc;/总库存struct book *next;/用链表建立图书信

9、息;int denglu2()/管理员登陆系统FILE *fp;struct xinxichar mnum20;/管理员登陆账号char mima20;/管理员登录密码temp;char mnum20,mima20;int m,n,i;for(i=0;ibookname,bookname);strcpy(p-ename,ename);strcpy(p-cnum,cnum);strcpy(p-pubpress,pubpress);strcpy(p-pubtime,pubtime);p-price=price;p-zc=zc;p-xc=xc;if(head=NULL)head=p;elsetail

10、-next=p;tail=p;fscanf(fp,%s%s%s%s%s%d%d%d,bookname,ename,cnum,pubpress,pubtime,&price,&zc,&xc);fclose(fp);tail-next=NULL;return head; struct book * addbook(struct book *head)/添加图书信息FILE *fp;struct book *p;int size=sizeof(struct book);char bookname20;/书名char ename20;/作者char cnum20;/分类号char pubpress20

11、;/出版社char pubtime20;/出版时间int price,zc,xc;/价格,总库存,现库存int n,i;printf(如果您已经添加完毕,请将分类号数输入为0,谢谢合作:n); printf(1.少量添加,所添加内容没有存在文件中n2.批量添加,内容在文件中存放n);printf(请输入编号:);scanf(%d,&i);switch(i)case 1:printf(请输入图书分类号:); scanf(%s,cnum); n=chashu(head,cnum); if(n=1) printf(您输入的分类号已存在,请重新输入!n); return head; while(str

12、cmp(cnum,0)!=0) n=chashu(head,cnum); if(n=1) printf(图书的分类号已存在,请重新输入!); return head; p=(struct book *)malloc(size); strcpy(p-cnum,cnum); printf(请输入图书名:); scanf(%s,bookname); strcpy(p-bookname,bookname); printf(请输入作者名:); scanf(%s,ename); strcpy(p-ename,ename); printf(请输入出版社:); scanf(%s,pubpress); strc

13、py(p-pubpress,pubpress); printf(请输入出版时间:); scanf(%s,pubtime); strcpy(p-pubtime,pubtime); printf(请输入价格:); scanf(%d,&price); p-price=price; printf(请输入总库存量:); scanf(%d,&zc); p-zc=zc; printf(请输入现库存量:); scanf(%d,&xc); p-xc=xc; head=insert1(head,p,cnum); printf(请输入图书分类号:); scanf(%s,cnum);break;case 2:if(f

14、p=fopen(book1.txt,r)=NULL)printf(File do not open!);exit(0);while(!feof(fp)p=(struct book *)malloc(size);fscanf(fp,%s,bookname);strcpy(p-bookname,bookname);fscanf(fp,%s,ename);strcpy(p-ename,ename);fscanf(fp,%s,cnum);strcpy(p-cnum,cnum);n=chashu(head,cnum);if(n=1)printf(图书的分类号已存在,请重新输入!);return head

15、;fscanf(fp,%s%s%d%d%d,pubpress,pubtime,&price,&zc,&xc);strcpy(p-pubpress,pubpress);strcpy(p-pubtime,pubtime);p-price=price;p-zc=zc;p-xc=xc;head=insert1(head,p,cnum);break;default:printf(输入错误!n);break;return head;int chashu(struct book * head,char m20)/查找图书是否存在int flag=0;struct book *p=NULL;if(head=N

16、ULL)return -1;/可添加该图书elsep=head;while(p!=NULL)if(strcmp(p-cnum,m)=0)flag=1;p=p-next;if(flag=1)return 1;/不可添加该图书else return -1;struct book *insert1(struct book *head,struct book *ptr,char cnum20)/增加接点struct book *p,*p1,*p2;p2=head;p=ptr;if (head=NULL)head=p1;p1-next=NULL;elsewhile(strcmp(p-cnum,p2-cn

17、um)0)&(p2-next!= NULL)p1=p2;p2=p2-next;if(strcmp(p-cnum,p2-cnum)next=p;p-next=p2;elsep2-next=p;p-next=NULL; return head;int putchoice()/选择查找内容int mychoice;printf(nttt1.按书名查找nttt2.按价格查找nttt3.按分类号查找nttt4.按作者查找nttt5.按时间查找nttt6.按出版社查找nttt0.退出nn);printf(请输入查询编号:);scanf(%d,&mychoice);return mychoice;void

18、chaname1(struct book * head)/按书名查找struct book *p;char shuname20;int flag=0; p=head;printf(请输入要查找的书名:);scanf(%s,shuname);printf(n);printf(查找结果如下n);printf(图书名t作者t分类号t出版社t出版时间t价格t总库存t现库存n);while(p!=NULL)if(strcmp(shuname,p-bookname)=0)printf(%st%st%st%st%stt%dt%dt%dt,p-bookname,p-ename,p-cnum,p-pubpres

19、s,p-pubtime,p-price,p-zc,p-xc);printf(n);flag=1;p=p-next;if(flag=0)printf(未找到你要找的书,请核实后再输!n);void sortbook(struct book * head)/排序选择int i;printf(nttt1-按图书名排序nttt2-按出版时间排序nttt3-按图书价格排序nttt4-按图书分类号排序nttt5-按作者名排序nttt6-按出版社排序nttt0-取消排序操作nn);printf(请输入您选择的选择:);scanf(%d,&i);switch(i)case 0:break;case 1:shu

20、ming(head); /按图书名排序break;case 2:ptime(head); /按出版时间排序break;case 3:price1(head); /按出版价格排序break;case 4:fenleihao(head); /按图书分类号排序break;case 5:zuo1(head); /按图书作者排序break;case 6:pre1(head); /按出版社排序default:printf(您的输入有误!n);break;其中,只给出按价格排序,其余省去。void price1(struct book * head)/按图书价格排序struct book *a100,*p,

21、*p1,*temp;int i,k,index,n=0;char ch;p1=head;for(p=head;p;p=p-next)n+;for(i=0;inext;for(k=0;kn-1;k+)index=k;for(i=k+1;ipriceprice)index=i; temp=aindex;aindex=ak;ak=temp; printf(排序成功!n);printf(是否显示排序结果?(y/n)n);scanf(%s,&ch); switch(ch)case n:break;case y: printf(图书名t作者t分类号t出版社t出版时间t价格t总库存t现库存n); for(i

22、=0;ibookname,ai-ename,ai-cnum,ai-pubpress,ai-pubtime,ai-price,ai.zc.ai.xc);break;default:printf(您的输入有误!n);break; 删除信息模块:struct book * shanchubook(struct book * head)/删除图书信息char num20;struct book *ptr1,*ptr2,*p; printf(请输入图书分类号:);scanf(%s,num);p=head;while(p!=NULL)if(strcmp(p-cnum,num)=0)break;p=p-ne

23、xt;if(p=NULL)printf(没有找到该号的图书!n);elsewhile(head!=NULL&head-next=NULL) if(strcmp(head-cnum,num)=0) ptr2=head; head=head-next; free(ptr2);if(head=NULL) return NULL; ptr1=head; ptr2=head-next; while(ptr2!=NULL) if(strcmp(ptr2-cnum,num)=0) ptr1-next=ptr2-next; free(ptr2); else ptr1=ptr2; ptr2=ptr1-next;

24、return head;修改图书信息模块:void xiugai(struct book *head)/修改图书信息int i;char cnum20;struct book *p;printf(请输入要修改的图书分类号:);scanf(%s,cnum);p=head;while(p!=NULL)if(strcmp(p-cnum,cnum)=0)break;p=p-next;if(p=NULL)printf(没有找到该号的图书!n);elseprintf(1-分类号 n2-图书名n3-作者名n4-出版社n5-出版时间n6-价格7-修改全部n0-放弃修改 n);case 1:printf(请输入

25、新分类号:);scanf(%s,p-cnum);fprint(head);printf(修改成功!n);break;修改图书信息只给出一部分,无论在添加,删除,还是在修改后,都需要将新链表写入文件保存起来,因此,就要调用下面的函数:void fprint(struct book *head)/将新链表写入文件中FILE *fp;struct book *p;if(fp=fopen(book.txt,w)=NULL)printf(File open error!n);exit(0);for(p=head;p!=NULL;p=p-next)fprintf(fp,%st%st%st%st%st%dt

26、%dt%dn,p-bookname,p-ename,p-cnum,p-pubpress,p-pubtime,p-price,p-zc,p-xc);fclose(fp);而浏览图书信息时就需要浏览函数:void printbook1(struct book * head)/浏览全部图书信息struct book * p;if(head=NULL)printf();return;printf(全部图书信息如下n);printf(书名t作者t分类号t出版社 t出版时间t价格t总库存t现库存n);for(p=head;p!=NULL;p=p-next)printf(%st%st%st%st%stt%d

27、t%dt%dn,p-bookname,p-ename,p-cnum,p-pubpress,p-pubtime,p-price,p-zc,p-xc);void pmenu(struct book * head,struct student s)int choice,m; m=jige();while(choice=inputchoice1()!=0)switch(choice)case 1:if(head=NULL)printf(图书馆管理系统出错,现在无法正常操作,给您带来的麻烦,我们深表歉意!n);break;elseprintbook(head);/图书查询break;case 2:if(

28、head=NULL)printf(图书馆管理系统出错,现在无法正常操作,给您带来的麻烦,我们深表歉意!n);break;elsesortbook(head);/图书排序break;case 3:if(head=NULL)printf(图书馆管理系统出错,现在无法正常操作,给您带来的麻烦,我们深表歉意!n);break;elseprintbook1(head);/浏览全部图书信息break;case 4:borrowbook(s,m,head);/借书break;case 5:backbook(s,m,head);/还书break;case 6:xmima(s,m);/修改密码break;cas

29、e 7:oneself(s,m);/查看个人资料break;default:printf(输入错误!n);break;借书与还书模块:void borrowbook(struct student s,int i,struct book * head)int m,n,t,p,flag=0,p1; char mnum20,mima20,cnum20,bookname20;if(i100)printf(借书人数已满,现不能借书!n);elseprintf(请输入帐号:);scanf(%s,mnum); printf(请输入密码:); scanf(%s,mima);for(t=0;ti;t+)if(s

30、trcmp(st.mnum,mnum)=0&strcmp(st.mima,mima)=0)printf(请输入图书的分类号:); scanf(%s,cnum);p1=huan(i,s,mnum); if(p1=1)m=chashu(head,cnum);/验证所借图书是否存在 if(m=1) n=chacun(head,cnum);/验证所借图书是否在库 if(n=1) strcpy(st.num,cnum); printf(请输入书名:); scanf(%s,bookname); strcpy(st.book,bookname); xwj(s,i); p=xcz(head,cnum);/把库

31、存量减1 if(p=-1) printf(借书失败!n); else printf(借书成功!n); flag=1; else printf(该书不在库!n);flag=1; else printf(该书不存在!n);flag=1; elseflag=1;printf(您已借书,不能再借,请还书后再借,谢谢合作!n);if(flag=0)printf(账号或密码有误!n);个人密码的修改:void xmima(struct student s,int i)int m,flag=0;char mnum20,mima20,a20;printf(请输入帐号:); scanf(%s,mnum); pr

32、intf(请输入密码:); scanf(%s,mima);for(m=0;mi;m+)if(strcmp(sm.mnum,mnum)=0&strcmp(sm.mima,mima)=0)printf(请输入新密码:);scanf(%s,a);strcpy(sm.mima,a);xwj(s,i);/将修改后的数组写入文件flag=1;if(flag=0)printf(账号或密码错误!n);个人信息的查询:void oneself(struct student s,int i)int m,f=0;char mnum20,mima20;printf(请输入帐号:);scanf(%s,mnum); printf(请输入密码:); scanf(%s,mima);for(m=0;mi;m+)if(strcmp(sm.mnum,mnum)=0&strcmp(sm.mima,mima)=0)f=1;printf(您的个人资料如下:n);printf(姓名t帐号t密码t借书名t分类号t电话t班级n);printf(%st%st%st%st%st%st%sn,sm.name,sm.mnum,sm.mima,sm.book,sm.num,sm.tel,sm.pclass);if(f=0)printf(您的密码或账号错误,请核对后重新输入!n);专心-专注-专业

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

当前位置:首页 > 教育专区 > 教案示例

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁