C--图书管理系统(共14页).doc
《C--图书管理系统(共14页).doc》由会员分享,可在线阅读,更多相关《C--图书管理系统(共14页).doc(14页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、精选优质文档-倾情为你奉上图书管理系统#include #include #include #define MAXSIZE 100 #define LIST_INIT_SIZE 100typedef struct Boro char BNum20; char RetDate8; struct Boro *next;Bor;typedef struct LinkBook Bor *next;/该图书证的借书行为 char CNum20;/证号 int Total;/借书的数量lendLIST_INIT_SIZE;/借书人数组/图书的结构体信息typedef struct LNode char C
2、ardNum20;/图书证号 struct LNode *next;LinkList; /借书人typedef struct book/每种图书需要登记的内容包括书号ISBN、书名、作者、出版社、总库存量和现库存量。 char num20;/书号 char name20;/书名 char auth20;/作者 char pub20;/出版社 int TotNum;/总库存 int NowNum;/现库存 LinkList *next;/借了该书的人ookMAXSIZE;/int Retotal;/读者数量int total; /定义外部变量.书的种类数/结构体初始化void InitBo(oo
3、k &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;/外部函数mid,用来返回查找到的位置bool BinarySearch(ook boo,char SearchNum) /二分法查找比较书号 /用bool函数,但由于函数不能有两个返回值,所以设置一个外部变量mid,用来返回查找到的位置 i
4、nt low=0,high=total-1; 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,&booi.name); printf(该书的作者是:); scanf( %s,&booi.aut
5、h); printf(该书的出版社是:); scanf( %s,&booi.pub);/补全信息 booi.next=NULL; total+;/总量+1 printf(已增加该书的信息。编号 %s 的书 %s 作者是 %s ,出版社是 %s ,目前的总库存是 %d ,现库存是 %d 。n,booi.num,booi.name,booi.auth,booi.pub,booi.TotNum,booi.NowNum); printf(入库成功.n); void Delete(ook &boo,char DeleteNum)/2、 清空库存:某一种书已无保留价值,将它从图书账目中注销。 if(Bin
6、arySearch(boo,DeleteNum)=false|total=0) /如果无此书 printf(书库中没有该书.n); if(BinarySearch(boo,DeleteNum)/若有 if(!boomid.next) int j; for( j=mid;j0) /看现库存是否大于0 boomid.NowNum-;/借出一本,少1 if(boomid.next=NULL) /若该书信息下显示该种书还没被人借过 m=(LinkList *)malloc(sizeof(LNode);/分配 boomid.next=m;/该图书信息中的链表的第一个结点 strcpy(m-CardNum
7、,CaNum); m-next=NULL;/后一个结点为空 else /如果已经有人在借这书了 m=boomid.next; while(m-next) /遍历到最后一个结点 m=m-next; n=(LinkList *)malloc(sizeof(LNode);/分配空间,增加1个结点 m-next=n; strcpy(n-CardNum,CaNum);/记录证号 n-next=NULL; int i=0; for(i=0;inext)p=p-next;/遍历到最后一个结点 q=(Bor *)malloc(sizeof(Boro);/分配空间 p-next=q; strcpy(q-BNum
8、,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+; /
9、借阅证号信息总数加1 printf(借阅成功.n); else printf(借阅失败.该书现在库存为0.n); void Return(ook &boo,lend &Lin,char ReturnNum,char BorrowerNum)/4、 归还:注销对借阅者的登记,改变该书的现存量。 Bor *p,*q; LinkList *m,*n; int flag=0;/设置一个参数 if(!BinarySearch(boo,ReturnNum)|!total) /没书 printf(书库中无此书.n); if(BinarySearch(boo,ReturnNum) /有书 m=boomid.n
10、ext; if(!strcmp(m-CardNum,BorrowerNum) /如果是第一个借的人还的 boomid.NowNum+; /现库存加1 boomid.next=m-next; /删除结点 free(m); /释放该结点的空间空间 else while(m-next) /查找归还者的借阅者结点 if(!strcmp(m-next-CardNum,BorrowerNum) /如果找到 n=m-next; /n为归还者的借阅结点 m-next=n-next; /m指向归还者的借阅结点的下一结点 free(n); /释放空间 boomid.NowNum+; /现库存加1 break; m
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 图书 管理 系统 14
限制150内