C--图书管理系统(共14页).doc
精选优质文档-倾情为你奉上图书管理系统#include <stdio.h>#include <string.h>#include <stdlib.h>#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 CardNum20;/图书证号 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(ook &boo) /初始化图书信息 for(int i=0;i<MAXSIZE;i+) booi.NowNum=0; booi.TotNum=0; booi.next=NULL; void InitRe(lend &Lin) /初始化借阅者信息 for(int i=0;i<LIST_INIT_SIZE;i+) Lini.next=NULL;/int mid=0;/外部函数mid,用来返回查找到的位置bool BinarySearch(ook boo,char SearchNum) /二分法查找比较书号 /用bool函数,但由于函数不能有两个返回值,所以设置一个外部变量mid,用来返回查找到的位置 int low=0,high=total-1; int found=0; while(low<=high) mid=(low+high)/2; /中间点 if(strcmp(boomid.num,SearchNum)=0) /书号相同 found=1; return true; /查找成功 if(strcmp(boomid.num,SearchNum)!=0)/书号不同 high=mid-1; else low=mid+1; if(found=0) return false; /查找失败void Buy(ook &boo, char BuyNum)/1、 采编入库:新购入一种书,如果该书在图书账目中已经存在,则将其库存量增加(包/括总库存量和现库存量),如果该书不存在,则在图书账目中增加一种书,总库存量和现库存量均为1。 if(BinarySearch(boo,BuyNum) /如果书库中有此书 boomid.TotNum+; /总库存加1 boomid.NowNum+; /现库存加1 printf("入库成功.n"); printf("已更改书库中该书的信息。编号 %s 的书 %s 作者是 %s ,出版社是 %s ,目前的总库存是 %d ,现库存是 %d 。n",boomid.num,boomid.name,boomid.auth,boomid.pub,boomid.TotNum,boomid.NowNum); if(!BinarySearch(boo,BuyNum) int i; for(i=total;i>mid&&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.auth); 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(BinarySearch(boo,DeleteNum)=false|total=0) /如果无此书 printf("书库中没有该书.n"); if(BinarySearch(boo,DeleteNum)/若有 if(!boomid.next) int j; for( j=mid;j<total;j+) booj=booj+1; strcpy(booj.num,booj+1.num); strcpy(booj.name,booj+1.name); strcpy(booj.auth,booj+1.auth); strcpy(booj.pub,booj+1.pub); booj.TotNum=booj+1.TotNum; booj.NowNum=booj+1.NowNum; printf("已成功删除该书.n"); else printf("该书有借阅者,无法删除。n"); void Borrow(ook &boo,lend &Lin,char BorrowNum,char CaNum)/3、 借阅:如果一种书的现库存量大于零,则借出一本书,将现库存量减1,/并登记借阅者的图书证号和归还期限。 Bor *p,*q; LinkList *m,*n; if(!BinarySearch(boo,BorrowNum)|total=0) /如果没有找到此书 printf("书库里没这书。n");/如果有这书 if(BinarySearch(boo,BorrowNum) /书库里有 if(boomid.NowNum>0) /看现库存是否大于0 boomid.NowNum-;/借出一本,少1 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);/分配空间,增加1个结点 m->next=n; strcpy(n->CardNum,CaNum);/记录证号 n->next=NULL; int i=0; for(i=0;i<Retotal;i+)/ if(!strcmp(Lini.CNum,CaNum)/如果已经有该图书证的信息 p=Lini.next; while(p->next)p=p->next;/遍历到最后一个结点 q=(Bor *)malloc(sizeof(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+; /借阅证号信息总数加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.next; 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=m->next; /在借阅者表里查找借阅者信息 for(int i=0;i<Retotal;i+) if(!strcmp(Lini.CNum,BorrowerNum) /如果找到借阅者 p=Lini.next; if(!strcmp(p->BNum,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; /q为归还书的借书结点 p->next=q->next; /p指向下一借书结点 free(q); /释放空间 printf("成功归还该书.n"); flag=1; break; p=p->next; for(int k=0;k<Retotal;k+) if(!Link.next) int j; for(j=k;j<Retotal;j+) Linj=Linj+1; /其后都往前移一位,覆盖掉当前信息 strcpy(Linj.CNum," "); /删除图书证号 Retotal-; /图书证数减1 /删除当前状态下没借书的图书证的信息,节省空间 if(flag=0) printf("无该证信息.n");/5、 查找:实现按三种查询条件之一查找:按书号查找、/按书名查找、按作者查找。注:可不实现组合查找,即几个条件组合查找。void SearchByNum(ook &boo,char SeaNum)/BY NUM 根据书号查找 LinkList *p; p=boomid.next; if(BinarySearch(boo,SeaNum)=false)printf("对不起,未找到您想查找的书。n");/二分查找 没找到 else/找到了的话 printf("n"); printf(" 书号 书名 作者 出版社 现库存 总库存 n"); printf("n"); printf("%14s%14s%16s%16s%10d%10dn",boomid.num,boomid.name,boomid.auth,boomid.pub,boomid.NowNum,boomid.TotNum); printf("n"); if(boomid.next!=NULL) printf("n"); printf(" 已借该书的 n"); printf(" 图书证号 n"); while(p) printf("n"); printf("%14sn",p->CardNum); p=p->next; printf("n"); while(p) printf(" %s ",p->CardNum);/在按书号查找的函数里也显示借了这本书的借阅者的证号 p=p->next; printf(" n"); /显示查找的书籍的信息void SearchByName(ook &boo)/BY NAME 根据书名查找 char SeaName20; printf("输入想查找的书的书名:n"); scanf(" %s",&SeaName); printf("找到符合该书名的书的详细信息如下:n"); for(int i=0;i<total;i+) if(strcmp(SeaName,booi.name)=0)/如果书名一样 printf("书号:%sn书名:%sn作者:%sn出版社:%sn总库存量:%dn现库存量:%dnn",booi.num,booi.name,booi.auth,booi.pub,booi.TotNum,booi.NowNum); /显示符合信息的所有书籍的信息 void SearchByAuth(ook &boo)/ BY AUTH 根据作者查找 char SeaAuth20; printf("输入想查找的书的作者:n"); scanf(" %s",&SeaAuth); printf("找到符合该作者的书的详细信息如下:n"); for(int i=0;i<total;i+) if(strcmp(SeaAuth,booi.auth)=0)/如果作者一样 printf("书号:%sn书名:%sn作者:%sn出版社:%sn总库存量:%dn现库存量:%dnn",booi.num,booi.name,booi.auth,booi.pub,booi.TotNum,booi.NowNum); /显示符合信息的所有书籍的信息 /6、 查看:可查看某图书证号的借阅者借阅的全部图书,可查看全部超期未还的图书。void ViewCard(ook &boo,lend &Lin)/查看某图书证号的借阅者借阅的全部图书 char Num20; printf("请输入您所想要查看的图书证号:n"); scanf(" %s",&Num); Bor *p; int qqq=0; for(int i=0;i<Retotal;i+) if(strcmp(Lini.CNum,Num)=0) /找到该证 printf("这个证借的书有:n"); p=Lini.next; while(p) printf(" %s ",p->BNum); /书号 p=p->next; printf("n"); qqq=1; break; if(qqq=0) printf("该证不存在.n");void ViewBook(ook &boo,lend &Lin)/查看全部超期未还的图书 char date8; Bor *p; printf("请输入日期(请按格式输入):n"); scanf(" %s",&date); printf("所有超期未还的书有:n"); for(int i=0;i<Retotal;i+) p=Lini.next; while(p)/当p不空时 if(strcmp(p->RetDate,date)<0) /超过日期 printf("书号为 %s 证号为 %s 应归还日期为 %s n",p->BNum,Lini.CNum,p->RetDate); /显示所有超期未还的书的信息 p=p->next; void Menu() /菜单 printf("M E N Un"); printf(" n"); printf(" 1. 采编入库:新购入一种书,如果该书在图书账目中已经存在, n"); printf(" 则将其库存量增加(包括总库存量和现库存量)。 n"); printf(" 如果该书不存在,则在图书账目中增加一种书, n"); printf(" 总库存量和现库存量均为输入的数字。 n"); printf(" 2. 清空库存:某一种书已无保留价值,将它从图书账目中注销。 n"); printf(" 3. 借阅:如果一种书的现库存量大于零,则借出一本书,将现库存量减1, n"); printf(" 并登记借阅者的图书证号和归还期限。 n"); printf(" 4. 归还:注销对借阅者的登记,改变该书的现存量。 n"); printf(" 5. 按书号查找。 n"); printf(" 6. 按书名查找。 n"); printf(" 7. 按作者查找。 n"); printf(" 8. 查看某图书证号的借阅者借阅的全部图书。 n"); printf(" 9. 查看全部超期未还的图书。 n"); printf(" 0. 退出图书管理系统。 n"); printf(" n"); printf("请 选 择 你 需 要 的 操 作n");void main() ook Bo; lend Lin; char BNum20; char CNum20; printf("-欢 迎 进 入 图 书 管 理 系 统!-nn"); int choice=10; int SearchCho=10,ViewCho=10; while(choice!=0) Menu();/显示菜单 scanf(" %d",&choice); switch(choice) case 1:/采编入库 printf("请输入入库的书的书号:"); scanf(" %s",BNum); Buy(Bo,BNum); break; case 2:/清空库存 printf("请输入想要清除的书的书号:"); scanf(" %s",BNum); Delete(Bo,BNum); break; case 3:/借阅 printf("请输入想要借阅的书的书号:n"); scanf(" %s",&BNum); printf("请输入图书证号:"); scanf(" %s",&CNum); Borrow(Bo,Lin,BNum,CNum); break; case 4:/归还 printf("请输入想要归还的书的书号:n"); scanf(" %s",&BNum); printf("请输入图书证号:"); scanf(" %s",&CNum); Return(Bo,Lin,BNum,CNum); break; case 5:/查找/根据书号查找 printf("请输入书号:");/输入书号查找 scanf(" %s",&BNum); SearchByNum(Bo,BNum); break; case 6:/根据书名查找 SearchByName(Bo); break; case 7:/根据作者查找 SearchByAuth(Bo); break; case 8:/查看某图书证所借的所有书 ViewCard(Bo,Lin); break; case 9: /查看全部超期未还的书 ViewBook(Bo,Lin); break; case 0:/退出系统 exit(0);break; default:printf("输入错误!n");exit(0);break; 专心-专注-专业