当前位置:新励学网 > 秒知问答 > 如何用C++建立一个图书馆数据库管理系统

如何用C++建立一个图书馆数据库管理系统

发表时间:2024-07-08 11:01:40 来源:网友投稿

#include

#include

#include

//

#defineMAXSIZE100//最大值定义为100

#defineLIST_INIT_SIZE100//图书证使用者最大值定义为100

//借书人的结构体

typedefstructBoro//借书行为

{

charBNum[20];//借书的书号

charRetDate[8];//归还日期

structBoro*next;

}Bor;

typedefstructLinkBook

{

Bor*next;//该图书证的借书行为

charCNum[20];//证号

intTotal;//借书的数量

}lend[LIST_INIT_SIZE];//借书人数组

//图书的结构体信息

typedefstructLNode

{

charCardNum[20];//图书证号

structLNode*next;

}LinkList;//借书人

typedefstructbook

{//每种图书需要登记的内容包括书号ISBN、书名、作者、出版社、总库存量和现库存量。

charnum[20];//书号

charname[20];//书名

charauth[20];//作者

charpub[20];//出版社

intTotNum;//总库存

intNowNum;//现库存

LinkList*next;//借了该书的人

}ook[MAXSIZE];

//

intRetotal;//读者数量

inttotal;//定义外部变量.书的种类数

//

//结构体初始化

voidInitBo(ook&boo)//初始化图书信息

{

for(inti=0;i<MAXSIZE;i++)

{

boo[i].NowNum=0;

boo[i].TotNum=0;

boo[i].next=NULL;

}

}

voidInitRe(lend&Lin)//初始化借阅者信息

{

for(inti=0;i<LIST_INIT_SIZE;i++)

Lin[i].next=NULL;

}

//

intmid=0;//外部函数mid,用来返回查找到的位置

boolBinarySearch(ookboo,charSearchNum[])//二分法查找比较书号

{//用bool函数,但由于函数不能有两个返回值,所以设置一个外部变量mid,用来返回查找到的位置

intlow=0,high=total-1;

intfound=0;

while(low<=high)

{

mid=(low+high)/2;//中间点

if(strcmp(boo[mid].num,SearchNum)==0)//书号相同

{

found=1;

returntrue;

}//查找成功

if(strcmp(boo[mid].num,SearchNum)!=0)//书号不同

high=mid-1;

elselow=mid+1;

}

if(found==0)

returnfalse;//查找失败

}

voidBuy(ook&boo,charBuyNum[])

{//1、采编入库:新购入一种书,如果该书在图书账目中已经存在,则将其库存量增加(包

//括总库存量和现库存量),如果该书不存在,则在图书账目中增加一种书,总库存量和现库存量均为1。

if(BinarySearch(boo,BuyNum))//如果书库中有此书

{

boo[mid].TotNum++;//总库存加1

boo[mid].NowNum++;//现库存加1

printf(入库成功.\n);

printf(已更改书库中该书的信息。编号%s的书%s作者是%s,出版社是%s,目前的总库存是%d,现库存是%d。\n,boo[mid].num,boo[mid].name,boo[mid].auth,boo[mid].pub,boo[mid].TotNum,boo[mid].NowNum);

}

if(!BinarySearch(boo,BuyNum))

{

inti;

for(i=total;i>mid&i--)//插在适合位置保持有序

boo[i]=boo[i-1];//空出插入位置

printf(该书在书库中不存在。设立新书目请补全书的详细信息。\n);

strcpy(boo[i].num,BuyNum);

printf(该书购入的数量是:);

scanf(%d,&boo[i].NowNum);

boo[i].TotNum=boo[i].NowNum;

printf(该书的名字是:);

scanf(%s,&boo[i].name);

printf(该书的作者是:);

scanf(%s,&boo[i].auth);

printf(该书的出版社是:);

scanf(%s,&boo[i].pub);//补全信息

boo[i].next=NULL;

total++;//总量+1

printf(已增加该书的信息。编号%s的书%s作者是%s,出版社是%s,目前的总库存是%d,现库存是%d。\n,boo[i].num,boo[i].name,boo[i].auth,boo[i].pub,boo[i].TotNum,boo[i].NowNum);

printf(入库成功.\n);

}

}

voidDelete(ook&boo,charDeleteNum[])

{//2、清空库存:某一种书已无保留价值,将它从图书账目中注销。

if(BinarySearch(boo,DeleteNum)==false||total==0)//如果无此书

printf(书库中没有该书.\n);

if(BinarySearch(boo,DeleteNum))//若有

{

if(!boo[mid].next)

{

intj;

for(j=mid;j<total;j++)

boo[j]=boo[j+1];

strcpy(boo[j].num,boo[j+1].num);

strcpy(boo[j].name,boo[j+1].name);

strcpy(boo[j].auth,boo[j+1].auth);

strcpy(boo[j].pub,boo[j+1].pub);

boo[j].TotNum=boo[j+1].TotNum;

boo[j].NowNum=boo[j+1].NowNum;

printf(已成功删除该书.\n);

}

elseprintf(该书有借阅者,无法删除。\n);

}

}

voidBorrow(ook&boo,lend&Lin,charBorrowNum[],charCaNum[])

{//3、借阅:如果一种书的现库存量大于零,则借出一本书,将现库存量减1,

//并登记借阅者的图书证号和归还期限。

Bor*p,*q;

LinkList*m,*n;

if(!BinarySearch(boo,BorrowNum)||total==0)//如果没有找到此书

printf(书库里没这书。\n);//如果有这书

if(BinarySearch(boo,BorrowNum))//书库里有

{

if(boo[mid].NowNum>0)//看现库存是否大于0

{

boo[mid].NowNum--;//借出一本,少1

if(boo[mid].next==NULL)//若该书信息下显示该种书还没被人借过

{

m=(LinkList*)malloc(sizeof(LNode));//分配

boo[mid].next=m;//该图书信息中的链表的第一个结点

strcpy(m->CardNum,CaNum);

m->next=NULL;//后一个结点为空

}

else//如果已经有人在借这书了

{

m=boo[mid].next;

while(m->next)//遍历到最后一个结点

m=m->next;

n=(LinkList*)malloc(sizeof(LNode));//分配空间,增加1个结点

m->next=n;

strcpy(n->CardNum,CaNum);//记录证号

n->next=NULL;

}

inti=0;

for(i=0;i<Retotal;i++)//

{

if(!strcmp(Lin[i].CNum,CaNum))//如果已经有该图书证的信息

{

p=Lin[i].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(Lin[i].CNum,CaNum);//记录证号

p=(Bor*)malloc(sizeof(Boro));//分配空间

Lin[i].next=p;

strcpy(p->BNum,BorrowNum);

printf(输入归还日期:);

scanf(%s,&p->RetDate);

p->next=NULL;

Retotal++;//借阅证号信息总数加1

printf(借阅成功.\n);

}

}

elseprintf(借阅失败.该书现在库存为0.\n);

}

}

voidReturn(ook&boo,lend&Lin,charReturnNum[],charBorrowerNum[])

{//4、归还:注销对借阅者的登记,改变该书的现存量。

Bor*p,*q;

LinkList*m,*n;

intflag=0;//设置一个参数

if(!BinarySearch(boo,ReturnNum)||!total)//没书

printf(书库中无此书.\n);

if(BinarySearch(boo,ReturnNum))//有书

{

m=boo[mid].next;

if(!strcmp(m->CardNum,BorrowerNum))//如果是第一个借的人还的

{

boo[mid].NowNum++;//现库存加1

boo[mid].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);//释放空间

boo[mid].NowNum++;//现库存加1

break;

}

m=m->next;

}

}

}

//在借阅者表里查找借阅者信息

for(inti=0;i<Retotal;i++)

{

if(!strcmp(Lin[i].CNum,BorrowerNum))//如果找到借阅者

{

p=Lin[i].next;

if(!strcmp(p->BNum,ReturnNum))//如果是归还的是借的第一本书

{

Lin[i].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(intk=0;k<Retotal;k++)

if(!Lin[k].next)

{

intj;

for(j=k;j<Retotal;j++)

Lin[j]=Lin[j+1];//其后都往前移一位,覆盖掉当前信息

strcpy(Lin[j].CNum,);//删除图书证号

Retotal--;//图书证数减1

}//删除当前状态下没借书的图书证的信息,节省空间

if(flag==0)printf(无该证信息.\n);

}

//5、查找:实现按三种查询条件之一查找:按书号查找、

//按书名查找、按作者查找。注:可不实现组合查找,即几个条件组合查找。

voidSearchByNum(ook&boo,charSeaNum[])

{//BYNUM根据书号查找

LinkList*p;

p=boo[mid].next;

if(BinarySearch(boo,SeaNum)==false)printf(对不起,未找到您想查找的书。\n);//二分查找没找到

else//找到了的话

{

{

printf(┏━━━━━━━┳━━━━━━━┳━━━━━━━━┳━━━━━━━━┳━━━━━┳━━━━━┓\n);

printf(┃书号┃书名┃作者┃出版社┃现库存┃总库存┃\n);

printf(┣━━━━━━━╋━━━━━━━╋━━━━━━━━╋━━━━━━━━╋━━━━━╋━━━━━┫\n);

printf(┃%14s┃%14s┃%16s┃%16s┃%10d┃%10d┃\n,boo[mid].num,boo[mid].name,boo[mid].auth,boo[mid].pub,boo[mid].NowNum,boo[mid].TotNum);

printf(┗━━━━━━━┻━━━━━━━┻━━━━━━━━┻━━━━━━━━┻━━━━━┻━━━━━┛\n);

if(boo[mid].next!=NULL)

{

printf(┏━━━━━━━┓\n);

printf(┃已借该书的┃\n);

printf(┃图书证号┃\n);

while(p)

{

printf(┣━━━━━━━┫\n);

printf(┃%14s┃\n,p->CardNum);

p=p->next;

}

printf(┗━━━━━━━┛\n);

}

}

while(p)

{

printf(%s,p->CardNum);//在按书号查找的函数里也显示借了这本书的借阅者的证号

p=p->next;

}

printf(\n);

}//显示查找的书籍的信息

}

voidSearchByName(ook&boo)

{//BYNAME根据书名查找

charSeaName[20];

printf(输入想查找的书的书名:\n);

scanf(%s,&SeaName);

printf(找到符合该书名的书的详细信息如下:\n);

for(inti=0;i<total;i++)

{

if(strcmp(SeaName,boo[i].name)==0)//如果书名一样

{

printf(书号:%s\n书名:%s\n作者:%s\n出版社:%s\n总库存量:%d\n现库存量:%d\n\n,boo[i].num,boo[i].name,boo[i].auth,boo[i].pub,boo[i].TotNum,boo[i].NowNum);

}//显示符合信息的所有书籍的信息

}

}

voidSearchByAuth(ook&boo)

{//BYAUTH根据作者查找

charSeaAuth[20];

printf(输入想查找的书的作者:\n);

scanf(%s,&SeaAuth);

printf(找到符合该作者的书的详细信息如下:\n);

for(inti=0;i<total;i++)

{

if(strcmp(SeaAuth,boo[i].auth)==0)//如果作者一样

{

printf(书号:%s\n书名:%s\n作者:%s\n出版社:%s\n总库存量:%d\n现库存量:%d\n\n,boo[i].num,boo[i].name,boo[i].auth,boo[i].pub,boo[i].TotNum,boo[i].NowNum);

}//显示符合信息的所有书籍的信息

}

}

//6、查看:可查看某图书证号的借阅者借阅的全部图书,可查看全部超期未还的图书。

voidViewCard(ook&boo,lend&Lin)

{//查看某图书证号的借阅者借阅的全部图书

charNum[20];

printf(请输入您所想要查看的图书证号:\n);

scanf(%s,&Num);

Bor*p;

intqqq=0;

for(inti=0;i<Retotal;i++)

{

if(strcmp(Lin[i].CNum,Num)==0)//找到该证

{

printf(这个证借的书有:\n);

p=Lin[i].next;

while(p)

{

printf(%s,p->BNum);//书号

p=p->next;

}

printf(\n);

qqq=1;

break;

}

}

if(qqq==0)

printf(该证不存在.\n);

}

voidViewBook(ook&boo,lend&Lin)

{//查看全部超期未还的图书

chardate[8];

Bor*p;

printf(请输入日期(请按格式20060605输入):\n);

scanf(%s,&date);

printf(所有超期未还的书有:\n);

for(inti=0;i<Retotal;i++)

{

p=Lin[i].next;

while(p)//当p不空时

{

if(strcmp(p->RetDate,date)<0)//超过日期

{

printf(书号为%s证号为%s应归还日期为%s\n,p->BNum,Lin[i].CNum,p->RetDate);

}//显示所有超期未还的书的信息

p=p->next;

}

}

}

voidMenu()//菜单

{

printf(┏—————————————————MENU————————————————┓\n);

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);

}

voidmain()

{

ookBo;

lendLin;

charBNum[20];

charCNum[20];

printf(-----------------------欢迎进入图书管理系统!---------------------------\n\n);

intchoice=10;

intSearchCho=10,ViewCho=10;

while(choice!=0)

{

Menu();//显示菜单

scanf(%d,&choice);

switch(choice)

{

case1://采编入库

printf(请输入入库的书的书号:);

scanf(%s,BNum);

Buy(Bo,BNum);

break;

case2://清空库存

printf(请输入想要清除的书的书号:);

scanf(%s,BNum);

Delete(Bo,BNum);

break;

case3://借阅

printf(请输入想要借阅的书的书号:\n);

scanf(%s,&BNum);

printf(请输入图书证号:);

scanf(%s,&CNum);

Borrow(Bo,Lin,BNum,CNum);

break;

case4://归还

printf(请输入想要归还的书的书号:\n);

scanf(%s,&BNum);

printf(请输入图书证号:);

scanf(%s,&CNum);

Return(Bo,Lin,BNum,CNum);

break;

case5://查找//根据书号查找

printf(请输入书号:);//输入书号查找

scanf(%s,&BNum);

SearchByNum(Bo,BNum);

break;

case6://根据书名查找

SearchByName(Bo);

break;

case7://根据作者查找

SearchByAuth(Bo);

break;

case8://查看某图书证所借的所有书

ViewCard(Bo,Lin);

break;

case9://查看全部超期未还的书

ViewBook(Bo,Lin);

break;

case0://退出系统

exit(0);break;

default:printf(输入错误!\n);exit(0);break;

}

}

}

免责声明:本站发布的教育资讯(图片、视频和文字)以本站原创、转载和分享为主,文章观点不代表本网站立场。

如果本文侵犯了您的权益,请联系底部站长邮箱进行举报反馈,一经查实,我们将在第一时间处理,感谢您对本站的关注!