数据结构课程设计报告图书馆管理系统(含源代码)

图书馆管理系统

专 业 班 级 :XXX 学 号 :XXX 姓 名 :XXX 指 导 教 师 :XXX 课程设计时间:XXX

注:本实验报告的实验源码需要到这里下载

数据结构 课程设计任务书

数据结构课程设计报告图书馆管理系统含源代码

一、设计题目

简单的图书馆管理系统

二、设计意义

熟悉和掌握数据结构课程所学的各种算法在实际项目中的应用,学习数据结构算法的c++实现方法等。

三、系统需求

程序中传递的有信息有:图书信息(包括图书编号、书名、作者、出版社、总库存和剩余库存)和读者信息(包括借阅证号和借阅图书)。

1.图书管理

对书库中的图书信息进行管理和查看功能,包括新书入库和清空库存功能,主要解决实际应用中图书馆增进新书种类数目或已有图书损坏丢失问题。其中,新书入库功能要求输入图书编号、书名、作者、出版社四项信息,用户输入图书编号后,系统首先判断书库中是否有该书的记录,如果满足条件,则要求输入购入数量后修改总库存和现有库存,如果不满足条件,则要求补全图书信息后新建一条库存记录;清空库存功能要求输入图书编号,用户输入图书编号后,系统首先判断书库中是否有该书的记录,如果满足条件,则删除书库中该书的记录,如果不满足条件,则返回错误提示。

2.借阅管理

管理书库中的图书借阅相关行为,包括图书借阅和图书归还功能,主要解决实际应用中图书馆图书借出和归还信息的管理的问题。其中,图书借阅功能要求输入图书编号,用户输入图书编号后,系统首先判断书库中是否有该书的记录以及是否还存在剩余库存,如果有且剩余库存大于0,则借出一本书,将该书现库存量减1,并登记借阅者的图书证号和归还期限,如果没有,则返回错误提示;图书归还功能要求输入图书编号和借阅证编号,用户输入图书编号和借阅证编号后,系统首先判断书库中是否有该书的记录及是否借出,如果满足条件,则归还一本书,将该书现库存量加1,并删除该借阅证下该条借阅记录,如果不满足条件,则返回错误信息。

3.图书查找

查找书库中的图书信息,包括按编号查找,按书名查找和按作者查找功

能,主要解决实际应用中借阅者查找想要借阅的图书信息和图书馆对图书各类信息的实时管理问题。其中,编号查找功能要求输入图书编号,用户输入图书编号后,系统首先判断书库中是否有该书的记录,如果满足条件,则输出包括图书编号、书名、作者、出版社、总库存和剩余库存等全部图书信息,如果不满足条件,则返回错误信息;书名查找功能要求输入图书书名,用户输入图书书名后,系统首先判断书库中是否有该书的记录,如果满足条件,则输出包括图书编号、书名、作者、出版社、总库存和剩余库存等全部图书信息,如果不满足条件,则返回错误信息;作者查找功能要求输入图书作者,用户输入图书作者后,系统首先判断书库中是否有该书的记录,如果满足条件,则输出包括图书编号、书名、作者、出版社、总库存和剩余库存等全部图书信息,如果不满足条件,则返回错误信息。

4.信息查看

查看书库中读者相关的借出相关信息,包括读者信息和超期未还功能,主要解决实际应用中图书馆管理者对书库中读者借阅信息和图书借阅信息的实时查看问题。读者信息功能要求输入借阅证编号,用户输入借阅证编号后,系统首先判断书库中是否有该读者的记录,如果满足条件,则输出读者所借阅的图书书名,如果不满足条件,则返回错误信息。超期未还功能要求输入当前日期,用户输入当前日期后,系统输出所有当前日期之前的所有图书借出记录。

四、功能设计

在仔细分析系统需求后决定按照需求分类设计程序模块,既图书管理、借阅管理、图书查找和信息查看四大模块以及新书入库、清空库存、图书借阅、图书归还、编号查找、书名查找、作者查找、读者信息和超期未还九大功能。为方便

数据结构课程设计报告图书馆管理系统含源代码

并决定函数按照功能划分,共使用函数十五个,包括两个公用函数用于库存检查和信息显示,一个菜单函数和九个分别对应九大功能的功能函数。他们分别是

数据结构课程设计报告图书馆管理系统含源代码

数据结构课程设计报告图书馆管理系统含源代码

五、运行环境(软、硬件环境)

1) 硬件:PC机

2) 操作系统:Windows 2000/XP/2003

3) 编译环境:Visual C++6.0

六、开发工具和编程语言

开发工具:VISCALL c++6.0;

编程语言:C++语言。

七、程序流程

数据结构课程设计报告图书馆管理系统含源代码

程序源代码

#include <iostream>

#include <string.h>

#include <stdlib.h>

using namespace std;

#define MAXSIZE 100 //最大值定义为100

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

typedef struct Boro //借书行为//借书人的结构体

{ char BNum[20]; //借书的书号

char RetDate[8]; //归还日期

struct Boro *next;

}Bor;

typedef struct LinkBook

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

char CNum[20]; //证号

int Total; //借书的数量

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

typedef struct LNode //图书的结构体信息

{ char CardNum[20]; //图书证号

struct LNode *next;

}LinkList; //借书人

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

{ char num[20]; //书号

char name[20]; //书名

char auth[20]; //作者

char pub[20]; //出版社

int TotNum; //总库存

int NowNum; //现库存

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

}ook[MAXSIZE];

int Retotal;//读者数量

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

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

{ for(int i=0;i<MAXSIZE;i++)

{ boo[i].NowNum=0;

boo[i].TotNum=0;

boo[i].next=NULL;

}}

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

{ for(int i=0;i<LIST_INIT_SIZE;i++)

Lin[i].next=NULL;

}

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

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

bool BinarySearch(ook boo,char SearchNum[])

{ int low=0,high=total-1;

int found=0;

while(low<=high)

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

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

{ found=1;return true;} //查找成功

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

high=mid-1;

else low=mid+1;}

if(found==0) return false; //查找失败

}

void Buy(ook &boo, char BuyNum[])

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

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

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

cout<<"入库成功."<<'\n';

cout<<"已更改书库中该书的信息。"<<'\n';

cout<<"┏━━━━━━━━┳━━━━━━━┓"<<'\n';

cout<<"┃ 编号 ┃"<<boo[mid].num<<'\n';

cout<<"┣━━━━━━━━╋━━━━━━━┫"<<'\n';

cout<<"┃ 书名 ┃"<<boo[mid].name<<'\n';

cout<<"┣━━━━━━━━╋━━━━━━━┫"<<'\n';

cout<<"┃ 作者 ┃"<<boo[mid].auth<<'\n';

cout<<"┣━━━━━━━━╋━━━━━━━┫"<<'\n';

cout<<"┃ 出版社 ┃"<<boo[mid].pub<<'\n';

cout<<"┣━━━━━━━━╋━━━━━━━┫"<<'\n';

cout<<"┃ 现库存 ┃"<<boo[mid].NowNum<<'\n';

cout<<"┣━━━━━━━━╋━━━━━━━┫"<<'\n';

cout<<"┃ 总库存 ┃"<<boo[mid].TotNum<<'\n';

cout<<"┗━━━━━━━━┻━━━━━━━┛"<<'\n';}

if(!BinarySearch(boo,BuyNum))

{ int i;

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

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

cout<<"该书在书库中不存在。设立新书目,请补全书的详细信息。"<<'\n'; strcpy(boo[i].num,BuyNum);

cout<<"该书购入的数量是:";

cin>>boo[i].NowNum;

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

cout<<"该书的名字是:";

cin>>boo[i].name;

cout<<"该书的作者是:";

cin>>boo[i].auth;

cout<<"该书的出版社是:";

cin>>boo[i].pub; //补全信息

boo[i].next=NULL;

total++; //总量+1

cout<<"已增加该书的信息。"<<endl;

cout<<"┏━━━━━━━━┳━━━━━━━┓"<<'\n';

cout<<"┃ 编号 ┃"<<boo[i].num<<'\n';

cout<<"┣━━━━━━━━╋━━━━━━━┫"<<'\n';

cout<<"┃ 书名 ┃"<<boo[i].name<<'\n';

cout<<"┣━━━━━━━━╋━━━━━━━┫"<<'\n';

cout<<"┃ 作者 ┃"<<boo[i].auth<<'\n';

cout<<"┣━━━━━━━━╋━━━━━━━┫"<<'\n';

cout<<"┃ 出版社 ┃"<<boo[i].pub<<'\n';

cout<<"┣━━━━━━━━╋━━━━━━━┫"<<'\n';

cout<<"┃ 现库存 ┃"<<boo[i].NowNum<<'\n';

cout<<"┣━━━━━━━━╋━━━━━━━┫"<<'\n';

cout<<"┃ 总库存 ┃"<<boo[i].TotNum<<'\n';

cout<<"┗━━━━━━━━┻━━━━━━━┛"<<'\n';

cout<<"入库成功。\n";}}

void Delete(ook &boo,char DeleteNum[])//2、 清空库存:某一种书已无保留价值,将它从图书账目中注销。

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

cout<<"书库中没有该书."<<'\n';

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

{ if(!boo[mid].next)

{ int j;

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;

cout<<"已成功删除该书."<<'\n';}

else cout<<"该书有借阅者,无法删除。"<<'\n';}}

//3、 借阅:如果一种书的现库存量大于零,则借出一本书,将现库存量减1,并登记借阅者的图书证号和归还期限。

void Borrow(ook &boo,lend &Lin,char BorrowNum[],char CaNum[])

{ Bor *p,*q;

LinkList *m,*n;

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

cout<<"书库里没这书。"<<'\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;}

int i=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); //记录书号

cout<<"输入归还日期:";

cin>>q->RetDate;

q->next=NULL;

cout<<"借阅成功。"<<'\n';

break;}} //找到证了就跳出循环

if(i==Retotal) //如果没有这张证的信息

{ strcpy(Lin[i].CNum,CaNum); //记录证号

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

Lin[i].next=p;

strcpy(p->BNum,BorrowNum);

cout<<"输入归还日期:";

cin>>p->RetDate;

p->next=NULL;

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

cout<<"借阅成功。"<<'\n';}}

else cout<<"借阅失败。该书现在库存为0。"<<'\n';}}

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

void Return(ook &boo,lend &Lin,char ReturnNum[],char BorrowerNum[]) { Bor *p,*q;

LinkList *m,*n;

int flag=0; //设置一个参数

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

cout<<"书库中无此书"<<'\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(int i=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); //释放结点空间

cout<<"成功归还该书。"<<'\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); //释放空间

cout<<"成功归还该书。"<<'\n';

flag=1;

break;}

p=p->next;}}}}

for(int k=0;k<Retotal;k++)

if(!Lin[k].next)

{ int j;

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

Lin[j]=Lin[j+1]; //其后都往前移一位,覆盖掉当前信息 strcpy(Lin[j].CNum," "); //删除图书证号 Retotal--;} //图书证数减1

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

if(flag==0) cout<<"无该证信息。"<<'\n';}

//5、 查找:实现按三种查询条件之一查找:按书号查找、按书名查找、按作者查找。注:可不实现组合查找,即几个条件组合查找。

void SearchByNum(ook &boo,char SeaNum[]) //BY NUM 根据书号查找 { LinkList *p;

p=boo[mid].next;

if(BinarySearch(boo,SeaNum)==false)

cout<<"对不起,未找到您想查找的书。"<<'\n'; //二分查找 没找到 else //找到了的话

{{ cout<<"┏━━━━━━━━┳━━━━━━━┓"<<'\n';

cout<<"┃ 书号 ┃"<<boo[mid].num<<'\n';

cout<<"┣━━━━━━━━╋━━━━━━━┫"<<'\n';

cout<<"┃ 书名 ┃"<<boo[mid].name<<'\n';

cout<<"┣━━━━━━━━╋━━━━━━━┫"<<'\n';

cout<<"┃ 作者 ┃"<<boo[mid].auth<<'\n';

cout<<"┣━━━━━━━━╋━━━━━━━┫"<<'\n';

cout<<"┃ 出版社 ┃"<<boo[mid].pub<<'\n';

cout<<"┣━━━━━━━━╋━━━━━━━┫"<<'\n';

cout<<"┃ 现库存 ┃"<<boo[mid].NowNum<<'\n';

cout<<"┣━━━━━━━━╋━━━━━━━┫"<<'\n';

cout<<"┃ 总库存 ┃"<<boo[mid].TotNum<<'\n';

cout<<"┗━━━━━━━━┻━━━━━━━┛"<<'\n';

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

{ cout<<"┏━━━━━━━┓"<<'\n';

cout<<"┃ 已借该书的 ┃"<<'\n';

cout<<"┃ 图书证号 ┃"<<'\n';

while(p)

{ cout<<"┣━━━━━━━┫"<<'\n';

cout<<"┃"<<p->CardNum<<"┃"<<'\n';

p=p->next;}

cout<<"┗━━━━━━━┛"<<'\n';}}

while(p)

{ cout<<p->CardNum; //在按书号查找的函数里也显示借了这本书的借阅者的证号

p=p->next;}

cout<<'\n';}} //显示查找的书籍的信息

void SearchByName(ook &boo) //BY NAME 根据书名查找

{ char SeaName[20];

cout<<"输入想查找的书的书名:"<<'\n';

cin>>SeaName;

cout<<"找到符合该书名的书的详细信息如下:"<<'\n';

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

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

{ cout<<"┏━━━━━━━━┳━━━━━━━┓"<<'\n';

cout<<"┃ 书号 ┃"<<boo[i].num<<'\n';

cout<<"┣━━━━━━━━╋━━━━━━━┫"<<'\n';

cout<<"┃ 书名 ┃"<<boo[i].name<<'\n';

cout<<"┣━━━━━━━━╋━━━━━━━┫"<<'\n';

cout<<"┃ 作者 ┃"<<boo[i].auth<<'\n';

cout<<"┣━━━━━━━━╋━━━━━━━┫"<<'\n';

cout<<"┃ 出版社 ┃"<<boo[i].pub<<'\n';

cout<<"┣━━━━━━━━╋━━━━━━━┫"<<'\n';

cout<<"┃ 现库存 ┃"<<boo[i].NowNum<<'\n';

cout<<"┣━━━━━━━━╋━━━━━━━┫"<<'\n';

cout<<"┃ 总库存 ┃"<<boo[i].TotNum<<'\n';

cout<<"┗━━━━━━━━┻━━━━━━━┛"<<'\n';

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

void SearchByAuth(ook &boo) // BY AUTH 根据作者查找

{ char SeaAuth[20];

cout<<"输入想查找的书的作者:"<<'\n';

cin>>SeaAuth;

cout<<"找到符合该作者的书的详细信息如下:"<<'\n';

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

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

{ cout<<"┏━━━━━━━━┳━━━━━━━┓"<<'\n';

cout<<"┃ 书号 ┃"<<boo[i].num<<'\n';

cout<<"┣━━━━━━━━╋━━━━━━━┫"<<'\n';

cout<<"┃ 书名 ┃"<<boo[i].name<<'\n';

cout<<"┣━━━━━━━━╋━━━━━━━┫"<<'\n';

cout<<"┃ 作者 ┃"<<boo[i].auth<<'\n';

cout<<"┣━━━━━━━━╋━━━━━━━┫"<<'\n';

cout<<"┃ 出版社 ┃"<<boo[i].pub<<'\n';

cout<<"┣━━━━━━━━╋━━━━━━━┫"<<'\n';

cout<<"┃ 现库存 ┃"<<boo[i].NowNum<<'\n';

cout<<"┣━━━━━━━━╋━━━━━━━┫"<<'\n';

cout<<"┃ 总库存 ┃"<<boo[i].TotNum<<'\n';

cout<<"┗━━━━━━━━┻━━━━━━━┛"<<'\n';

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

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

void ViewCard(ook &boo,lend &Lin) //查看某图书证号的借阅者借阅的全部图书

{ char Num[20];

cout<<"请输入您所想要查看的图书证号:"<<'\n';

cin>>Num;

Bor *p;

int qqq=0;

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

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

{ cout<<"这个证借的书有:"<<'\n';

p=Lin[i].next;

while(p)

{ cout<<p->BNum; //书号

p=p->next;}

cout<<'\n';

qqq=1;

break;}}

if(qqq==0)

cout<<"该证不存在."<<'\n';}

void ViewBook(ook &boo,lend &Lin) //查看全部超期未还的图书

{ char date[8];

Bor *p;

cout<<"请输入日期(请按格式20060605输入):"<<'\n';

cin>>date;

cout<<"所有超期未还的书有:"<<'\n';

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

{ p=Lin[i].next;

while(p) //当p不空时

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

{ cout<<"┏━━━━━━━━┳━━━━━━━┓"<<'\n';

cout<<"┃ 书号 ┃"<<p->BNum<<'\n';

cout<<"┣━━━━━━━━╋━━━━━━━┫"<<'\n';

cout<<"┃ 证号 ┃"<<Lin[i].CNum<<'\n';

cout<<"┣━━━━━━━━╋━━━━━━━┫"<<'\n';

cout<<"┃ 归还日期 ┃"<<p->RetDate<<'\n';

cout<<"┗━━━━━━━━┻━━━━━━━┛"<<'\n';}//显示所有超期未

还的书的信息

p=p->next;}}}

void Menu() //菜单

{ cout<<"┏—————————————————M E N U——————

——————————┓";

cout<<"│ │";

cout<<"│ 1. 采编入库:新购入一种书,如果该书在图书账目中已经存在,则

将其库存量增 │";

cout<<"│ 加(包括总库存量和现库存量)。如果该书不存在,

则在图书账目中 │";

cout<<"│ 增加一种书,总库存量和现库存量均为输入的数字。 │";

cout<<"│ 2. 清空库存:某一种书已无保留价值,将它从图书账目中注销。 │";

cout<<"│ 3. 借 阅:如果一种书的现库存量大于零,则借出一本书,将现

库存量减1,并 │";

cout<<"│ 登记借阅者的图书证号和归还期限。 │";

cout<<"│ 4. 归 还:注销对借阅者的登记,改变该书的现存量。 │";

cout<<"│ 5. 按书号查找。 │";

cout<<"│ 6. 按书名查找。 │";

cout<<"│ 7. 按作者查找。 │";

cout<<"│ 8. 查看某图书证号的借阅者借阅的全部图书。 │";

cout<<"│ 9. 查看全部超期未还的图书。 │";

cout<<"│ 0. 退出图书管理系统。 │";

cout<<"│ │";

cout<<"┗—————————————请 选 择 你 需 要 的 操 作———

—————————┛";

}

void main()

{ ook Bo;

lend Lin;

char BNum[20];

char CNum[20];

cout<<"-----------------------欢 迎 进 入 图 书 管 理 系

统!---------------------------"<<'\n';

int choice=10;

int SearchCho=10,ViewCho=10;

while(choice!=0)

{ Menu(); //显示菜单

cin>>choice;

switch(choice)

{

case 1: //采编入库

cout<<"请输入入库的书的书号:";

cin>>BNum;

Buy(Bo,BNum);

break;

case 2: //清空库存

cout<<"请输入想要清除的书的书号:";

cin>>BNum;

Delete(Bo,BNum);

break;

case 3: //借阅

cout<<"请输入想要借阅的书的书号:"<<'\n'; cin>>BNum;

cout<<"请输入图书证号:";

cin>>CNum;

Borrow(Bo,Lin,BNum,CNum);

break;

case 4: //归还

cout<<"请输入想要归还的书的书号:"<<'\n'; cin>>BNum;

cout<<"请输入图书证号:";

cin>>CNum;

Return(Bo,Lin,BNum,CNum);

break;

case 5: //查找//根据书号查找

cout<<"请输入书号:";//输入书号查找 cin>>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:cout<<"输入错误!"<<'\n';

exit(0);

break;

}}}

八、测试结果

数据结构课程设计报告图书馆管理系统含源代码

数据结构课程设计报告图书馆管理系统含源代码

数据结构课程设计报告图书馆管理系统含源代码

数据结构课程设计报告图书馆管理系统含源代码

九、 参考文献

[1] 边肇祺,模式识别(第二版),北京:清华大学出版社,1988,25~35

[2] 李永忠,几种小波变换的图像处理技术,西北民族学院学报(自然科学版),2001.6,22(3),15~18

[3]谭浩强,C程序设计题解与上机指导(第3版),清华大学出版社,2005.7.

[4][美]Harvey M. Deitel,Paul J. Deitel 著,聂雪军,贺军译,C程序设

计经典教程(第4版),清华大学出版社,2006。3

课程设计总结

通过本次课程设计,我学到了很多:增强了查阅相关参考资料的能力;独立分析解决问题的能力;创新精神;自己的上机动手的能力;自己对课程设计的理解,得到很多启示,知道了以后要加强哪一方面,还有哪一方面有用,课程设计为我们提供了一个即动手又动脑、独立实践的机会,让我明白了在我们学习理论知识的同时,应该积极上机实验以巩固我们的理论知识,增强我们设计程序的能力,为我们将来的工作打下坚实的基础。

相关推荐