数据结构图书管理方案报告.doc
.-一实验目的图书管理: 图书管理基本业务活动包括:对一本书的采编入库、清除库存。借阅和归还等等。试设计一个图书管理系统,将上述业务活动借助于计算机系统完成。二实验内容计一个计算机管理系统完成图书管理基本业务。【基本要求】1) 每种书的登记内容包括书号、书名、著作者、现存量和库存量;2) 对书号建立索引表(线性表)以提高查找效率;3) 系统主要功能如下:*采编入库:新购一种书,确定书号后,登记到图书帐目表中,如果表中已有,则只将库存量增加;*借阅:如果一种书的现存量大于0,则借出一本,登记借阅者的书证号和归还期限,改变现存量;*归还:注销对借阅者的登记,改变该书的现存量。三实验步骤(可选)1.图书馆基本操作函数void delbook() tag=1; /设置删除标记 1:已删 0:未删void addreader(int n,char *na)/增加读者 tag=0;no=n;strcpy(name,na);for(int i=0;i<Maxbor;i+)borbooki=0;void borrowbook(int bookid)/借书操作for(int i=0;i<Maxbor;i+) if (borbooki=0)borbooki=bookid;return;int retbook(int bookid)/还书操作 for(int i=0;i<Maxbor;i+) if(borbooki=bookid)borbooki=0;return 1;return 0;void disp()/读出读者信息 cout << setw(5) << no <<setw(10) << name<<"借书编号:"for(int i=0;i<Maxbor;i+)if(borbooki!=0)cout << borbooki << "|"cout << ""<<endl;2. 读者类库,实现建立读者的个人资料 class RDatabase private: int top; /读者记录指针 Reader readMaxr;/读者记录public:RDatabase() /构造函数,将reader.txt读到read中Reader s;top=-1;fstream file("reader.txt",ios:in);/打开一个输入文件while (1)file.read(char *)&s,sizeof(s);if (!file)break;top+;readtop=s;file.close(); /关闭 reader.txt void clear()/删除所有读者信息top=-1;int addreader(int n,char *na)/添加读者时先查找是否存在Reader *p=query(n);if (p=NULL) top+; readtop.addreader(n,na); return 1;return 0;Reader *query(int readerid)/按编号查找for (int i=0;i<=top;i+)if (readi.getno()=readerid && readi.gettag()=0)return &readi;return NULL;void disp() /输出所有读者信息 for (int i=0;i<=top;i+) readi.disp();void readerdata();/读者库维护RDatabase() /析构函数,将read写到reader.txt文件中fstream file("reader.txt",ios:out); for (int i=0;i<=top;i+)if (readi.gettag()=0)file.write(char *)&readi,sizeof(readi);file.close();void RDatabase:readerdata() char choice;char rname20;int readerid;Reader *r;while (choice!=0)cout <<"读者维护:t1新增t2更改t3删除t4查找t5显示t6全删t0退出"<<endl;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 << " 该读者不存在 "<<endl; break;cout << "输入新的姓名:"cin >> rname;r->setname(rname); break; case 3: cout << " 输入读者编号:" cin >> readerid;r=query(readerid);if (r=NULL) cout <<" 该读者不存在" << endl; break;r->delbook();break;case 4:cout << "读入读者编号:"cin >> readerid;r=query(readerid);if (r=NULL)cout <<"该读者不存在"<< endl;break;r->disp();break;case 5:disp();break;case 6:clear();break;default:cout<<"输入错误,请从新输入:"break;四实验的结果及分析。实验结果:实验结果分析:图书管理系统分为图书管理和会员管理两大部分。设计一个图书类Book,包括一本图书的基本管理功能。再设计一个图书库类BDatabase,具有以下私有数据:int top; /图书记录指针Book bookMaxb; /图书记录。在其构造函数中,将book.txt文件的所有录入读到book中。处理完毕,在析构函数中将book中的所有未删除记录笑道book.txt文件中,中间的处理是对book进行的。设计一个读者类Reader,包括一个读者的基本管理功能。在其构造函数中,将reader.txt文件的所有记录读到read中。处理完毕,在析构函数中将read中的所有未删除记录写到reader.txt文件中,中间的处理都是对reader进行的。五实验中出现的问题、解决方法和心得体会本实验是这个学期的最后一个实验,我选择的是图书管理系统的设计。这个实验的设计有一定的难度,花费的时间比较长。虽然做过了很多实验,但是这个实验操作中还是遇到了很多问题,所以特意到图书馆专门借了几本关于数据结构程序设计方面的书,希望能对知识有更深层次的理解。一切准备就绪,把平时写的相关的程序出来参考,对比,慢慢才找到一些感觉,把源程序写出来。比起前面的几个实验,这个设计的功能完成的比较全面,也有原因是有前面的实验作为基础。虽然这学期的数据结构课程已经学完,但这并不是学习编程的结束。虽然做了很多份设计,但基本还要参考资料或问老师和同学,所以,在以后的学习中,还应该继续多做题,多独立思考,争取在编程上取得一定的进步,点点滴滴积累下来的能量是无穷的。所以我要脚踏实地、从点滴做起。