数据结构图书管理系统.docx
- 文档编号:18113133
- 上传时间:2023-08-13
- 格式:DOCX
- 页数:43
- 大小:195.94KB
数据结构图书管理系统.docx
《数据结构图书管理系统.docx》由会员分享,可在线阅读,更多相关《数据结构图书管理系统.docx(43页珍藏版)》请在冰点文库上搜索。
数据结构图书管理系统
石河子大学信息科学与技术学院计算机科学与技术专业课程设计报告
二、结构图
1.功能结构图
图书
管理
系统
新增图
查询在
恢复被
为读者
办理借
办理还
退出系
书信息
架的图
删除图
办理借
书手续
书手续
统
的输入
书信息
书信息
书注册
2.主流程图
Start
设置选择变量choice
输出提示
让用户选择要实行的操作.
借书功能
还书功能
图书维护
读者维护
退出系统
Choice=
Choice=1
Choice=2
Choice=3
Choice=4
Choice=0
‘其它数值’
提示输入错误
Stop
三、程序设计的想法和具体思路
图书管理系统分为图书管理和会员管理两大部分。
设计一个图书类Book,包括一本图书的
基本管理功能,具有以下私有数据:
inttag;//删除标记1:
已删0:
未删
intno;//图书编号
charname[20];//书名
intonshelf;//是否再架1:
再架2:
已借
设计一个图书库类BDatabase,具有以下私有数据:
1
inttop;//图书记录指针
Bookbook[Maxb];//图书记录
在其构造函数中,将book.txt文件的所有录入读到book[]中。
处理完毕,在析构函数
中将book[]中的所有未删除记录笑道book.txt文件中,中间的处理是对book[]进行的。
设计一个读者类Reader,包括一个读者的基本管理功能,具有以下私有数据:
inttag;//删除标记1:
已删0:
未删
intno;//读者编号
charname[10];//读者姓名
intborbook[Maxbor];//所借图书
设计一个读者库类RDatabase,具有以下私有数据:
inttop;//读者记录指针
Readerread[Maxr];//读者记录
在其构造函数中,将reader.txt文件的所有记录读到read[]中。
处理完毕,在析构函
数中将read[]中的所有未删除记录写到reader.txt文件中,中间的处理都是对reader[]
进行的。
四、参考文献
1)谭浩强,《C++程序设计》,北京,清华大学出版社,2006年
2)李振鹏,张小莉,郑艳娟,《数据结构》,中国铁道出版社,2007年
3)杨小平,《VisualC++项目案例导航》,北京,科学出版社,
2002年
4)DavidConger,《软件开发:
编程与设计》,北京,清华大学出版社,2006年.
5)FrancisGlassborowRobertaAllen,《YouCanDoIt!
——C++编程新手
互动教程》,北京,人民邮电出版社,2005年
五、课程设计总结
心得体会
选到这个课程设计题目的时候,感觉挺简单的,查找,增加,,显示,统计,这些
平时都学过,用过,但是实际操作中还是遇到了很多问题,所以特意到图书馆专门
借了几本关于数据结构程序设计方面的书,同时也希望能把平时没有学好的地方好好补一补,能对知识有更深层次的理解.一切准备就绪,把平时写的相关的程序出来参考,对比,慢慢才找到一些感觉,把源程序写出来.经过几天终于写完了程序的初稿,然后输入电脑,一编译,发现错误几十个,还有好多警告,只得一条一条的看,
一个一个的改,首当其冲的是再输入电脑过程中不小心漏掉的标点符号,有些括号
2
忘了,有些是忘了写分号等粗心导致的小毛病,这些错误很容易改正.到后面的错
误就有些麻烦了,当中有个头文件忘了写,编译过程中好几十个错误就是改不过来,
后来和同学讨论才知道原来错在什么地方,这样一下就变成了几个错误,这时信心
大增,有些错误都看不懂错在那里,由于英文水平不太好,只好去查字典,还要推敲
这个单词在这里到底是哪个意思,再加上以往的经验和同学的帮助下,好不容易才得到零错误零警告,那时真开心,我的程序终于可以运行了,激动的按下运行,得到了预想的界面,按照提示操作,都很顺利,一个一个的实验每一个功能,都以为成功
了,当运行到了删除功能时,突然出现死循环,只见操作界面不停的闪.这是逻辑错误,很难找,后来只有一步一步的,一句一句的检查,找到了错误的根源,并改正.
从进入大学来,我们学习了C++,数据结构。
特别是高老师的认真授课,精心讲解下,同学们学到了很多东西,知识方面的很多,还有平时?
心的习惯也养成了.
这对我们以后的学习生活很有好处,最后感谢常老师一学期以来对我们的教育帮
助,对我们程序设计时的辅导.
六、程序运行结果
3
附录:
源代码
#include
#include
4
#include
#include
usingnamespacestd;
constintMaxr=100;//最多的读者
constintMaxb=100;//最多的图书
constintMaxbor=5;//每位读者最多借五本书
//读者类,实现对读者的信息的描述
classReader
{
private:
inttag;//删除标记1:
已删0:
未删
intno;//读者编号
charname[10];//读者姓名
intborbook[Maxbor];//所借图书
public:
Reader(){}
char*getname(){returnname;}//获取姓名
intgettag(){returntag;}//获取删除标记
intgetno(){returnno;}//获取读者编号
voidsetname(charna[])//设置姓名
{
strcpy(name,na);
}
voiddelbook(){tag=1;}//设置删除标记1:
已删0:
未删
voidaddreader(intn,char*na)//增加读者
{
tag=0;
no=n;
strcpy(name,na);
for(inti=0;i borbook[i]=0; } voidborrowbook(intbookid)//借书操作 { for(inti=0;i { if(borbook[i]==0) { borbook[i]=bookid; return; } } } intretbook(intbookid)//还书操作 5 { for(inti=0;i { if(borbook[i]==bookid) { borbook[i]=0; return1; } } return0; } voiddisp()//读出读者信息 { cout< ["; for(inti=0;i if(borbook[i]! =0) cout< cout<<"]"< } }; //读者类库,实现建立读者的个人资料 classRDatabase { private: inttop;//读者记录指针 Readerread[Maxr];//读者记录 public: RDatabase()//构造函数,将reader.txt读到read[]中 { Readers; top=-1; fstreamfile("reader.txt",ios: : in);//打开一个输入文件while (1) { file.read((char*)&s,sizeof(s)); if(! file)break; top++; read[top]=s; } file.close();//关闭reader.txt } voidclear()//删除所有读者信息 { top=-1; 6 } intaddreader(intn,char*na)//添加读者时先查找是否存在 { Reader*p=query(n); if(p==NULL) { top++; read[top].addreader(n,na); return1; } return0; } Reader*query(intreaderid)//按编号查找 { for(inti=0;i<=top;i++) if(read[i].getno()==readerid&& read[i].gettag()==0) { return&read[i]; } returnNULL; } voiddisp()//输出所有读者信息 { for(inti=0;i<=top;i++) read[i].disp(); } voidreaderdata();//读者库维护 ~RDatabase()//析构函数,将read[]写到reader.txt文件中 { fstreamfile("reader.txt",ios: : out); for(inti=0;i<=top;i++) if(read[i].gettag()==0) file.write((char*)&read[i],sizeof(read[i])); file.close(); } }; voidRDatabase: : readerdata() { charchoice; charrname[20]; intreaderid; Reader*r; while(choice! ='0') 7 { cout<<"读者维护: t1.新增t2.更改t3.删除t4.查找t5.显示t6.全删t0.退出"< cin>>choice; switch(choice) { case'1': cout<<"输入读者编号: "; cin>>readerid; cout<<"输入读者姓名: "; cin>>rname; addreader(readerid,rname); break; case'2': cout<<"输入读者编号: "; cin>>readerid; r=query(readerid); if(r==NULL) { cout<<"该读者不存在"< break; } cout<<"输入新的姓名: "; cin>>rname; r->setname(rname); break; case'3': cout<<"输入读者编号: "; cin>>readerid; r=query(readerid); if(r==NULL) { cout<<"该读者不存在"< break; } r->delbook(); break; case'4': cout<<"读入读者编号: "; cin>>readerid; r=query(readerid); if(r==NULL) { cout<<"该读者不存在"< break; 8 } r->disp(); break; case'5': disp(); break; case'6': clear(); break; default: cout<<"输入错误,请从新输入: ";break; } } } //图书类,实现对图书的描述,图书的编号,书名,借出,还入等 classBook { private: inttag;//删除标记1: 已删0: 未删 intno;//图书编号 charname[20];//书名 intonshelf;//是否再架1: 再架2: 已借 public: Book(){} char*getname(){returnname;}//获取姓名 intgetno(){returnno;}//获取图书编号 intgettag(){returntag;}//获取删除标记 voidsetname(charna[])//设置书名 { strcpy(name,na); } voiddelbook(){tag=1;}//删除图书 voidaddbook(intn,char*na)//增加图书 { tag=0; no=n; strcpy(name,na); onshelf=1; } intborrowbook()//借书操作 { if(onshelf==1) { onshelf=0; return1; 9 } return0; } voidretbook()//还书操作 { onshelf=1; } voiddisp()//输出图书 { cout< <<(onshelf==1? "在架": "已借")< } }; //图书库类,实现对图书的维护,查找,删除等 classBDatabase { private: inttop;//图书记录指针 Bookbook[Maxb];//图书记录 public: BDatabase()//构造函数,将book.txt读到book[]中 { Bookb; top=-1; fstreamfile("book.txt",ios: : in); while (1) {file.read((char*)&b,sizeof(b)); if(! file)break; top++; book[top]=b; } file.close(); } voidclear()//全删 { top=-1; } intaddbook(intn,char*na)//增加图书 { Book*p=query(n); if(NULL==p) { top++; book[top].addbook(n,na); 10 return1; } return0; } Book*query(intbookid)//查找图书 { for(inti=0;i<=top;i++) if(book[i].getno()==bookid&&book[i].gettag()==0) { return&book[i]; } returnNULL; } voidbookdata();//图书库维护 voiddisp() { for(inti=0;i<=top;i++) if(book[i].gettag()==0) book[i].disp(); } ~BDatabase()//析构函数,将book[]写到book.txt文件中 { fstreamfile("book.txt",ios: : out); for(inti=0;i<=top;i++) if(book[i].gettag()==0) file.write((char*)&book[i],sizeof(book[i])); file.close(); } }; voidBDatabase: : bookdata() { charchoice; charbname[40]; intbookid; Book*b; while(choice! ='0') { cout<<"图书维护: t1.新增t2.更改t3.删除t4.查找t5.显示t6.全删t0.退出"< cin>>choice; switch(choice) { case'1': cout<<"输入图书编号: "< cin>>bookid; 11 cout<<"输入图书书名: "< cin>>bname; addbook(bookid,bname); break; case'2': cout<<"输入图书编号: "< cin>>bookid; b=query(bookid); if(b==NULL) { cout<<"该图书不存在"< break; } cout<<"输入新的书名: "< cin>>bname; b->setname(bname); break; case'3': cout<<"读入图书编号: "< cin>>bookid; b=query(bookid); if(b==NULL) { cout<<"该图书不存在"< break; } b->delbook(); break; case'4': cout<<"读入图书编号: "< cin>>bookid; b=query(bookid); if(b==NULL) { cout<<"该图书不存在"< break; } b->disp(); break; case'5': disp(); break; case'6': clear(); 12 break; default: cout<<"输入错误,请从新输入: "; } } } //main()函数的实现,程序的主界面的引导 voidmain() { charchoice; intbookid,readerid; RDatabaseReaderDB; Reader*r; BDatabaseBookDB; Book*b; while(choice! ='0') {cout< cout<<"1.借书t2.还书t3.图书维护t4.读者维护t0.离开"< switch(choice) { case'1': cout<<"借书n读者编号: "; cin>>readerid; cout<<"图书编号: "; cin>>bookid; r=ReaderDB.query(readerid);//按编号查找 if(NULL==r) { cout<<"不存在该读者,不能借书"< break; } b=BookDB.query(bookid); if(b==NULL) { cout<<"不存在该图书,不能借书"< break;} if(b->borrowbook()==0) { cout<<"该图书已借出,不能借书"< break; } r->borrowbook(b->getno()); break; case'2': 13 cout<<"还书n读者编号: "; cin>>readerid; cout<<"图书编号: "; cin>>bookid; r=ReaderDB.query(readerid); if(r==NULL) { cout<<"不存在该读者,不能还书"< break; } b=BookDB.query(bookid); if(b==NULL) { cout<<"不存在该图书,不能还书"< break; } b->retbook(); r->retbook(b->getno()); break; case'3': BookDB.bookdata(); break; case'4': ReaderDB.readerdata(); break; default: cout<<"输入错误,请从新输入: "; } } } 14
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构 图书 管理 系统