




免费预览已结束,剩余11页可下载查看
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
#include #include #include #include using namespace std;const int Reader=100;const int Maxb=100;const int Bor=5;class Studentprivate: int tag; int number; char name10; int borbookBor;public: Student() char *getname() return name;int gettag() return tag;int getnumber() return number;void setname(char *na) strcpy(name,na);void delbook() tag=1;void addStudent(int n,char *na) tag=0; number=n; strcpy(name,na); for(int i=0;iBor;i+) borbooki=0;void borrowbook(int bookid)/借书操作for(int i=0;iBor;i+) if (borbooki=0) borbooki=bookid; return; int retbook(int bookid)/还书操作 for(int i=0;iBor;i+) if(borbooki=bookid) borbooki=0; return 1;return 0;void output()/读出读者信息 cout setw(5) number setw(10) name借书编号:; for(int i=0;iBor;i+) if(borbooki!=0) cout borbooki |; cout endl; class RDataprivate: int top; /读者记录指针 Student readReader;public: RData() /构造函数,将Student.txt读到read中 Student s; top=-1; fstream file(Student.txt,ios:in);/打开一个输入文件while (1) file.read(char *)&s,sizeof(s); if (!file)break; top+; readtop=s; file.close();void clear() top=-1;int addStudent(int n,char *na)/查找是否存在 Student *p=equal(n);if (p=NULL) top+; readtop.addStudent(n,na); return 1;return 0;Student *equal(int Studentid)/按编号查找for (int i=0;i=top;i+) if (readi.getnumber()=Studentid & readi.gettag()=0) return &readi;return NULL;void output() for (int i=0;i=top;i+) readi.output();void Studentdata();/读者库维护 RData() /析构函数,将read写到Student.txt文件中 fstream file(Student.txt,ios:out); for (int i=0;i=top;i+) if (readi.gettag()=0) file.write(char *)&readi,sizeof(readi); file.close();void RData:Studentdata()char choice;char rname20;int Studentid;Student *r; while (choice!=0) cout n; cout 读 者 维 护 n; cout n; cout 1.新 增 n; cout n; cout 2.更 改 n; cout n; cout 3.删 除 n; cout n; cout 4.查 找 n; cout n; cout 5.显 示 n; cout n; cout 6.全 删 n; cout n; cout 0.退出 n; cout n; /cout choice; switch (choice) case 1: cout Studentid; cout rname; addStudent (Studentid,rname); break; case 2: cout Studentid; r=equal(Studentid); if (r=NULL) cout 该读者不存在 endl; break; cout rname; r-setname(rname); break; case 3: cout Studentid; r=equal(Studentid); if (r=NULL) cout 该读者不存在 delbook(); break; case 4: cout Studentid; r=equal(Studentid); if (r=NULL) cout 该读者不存在output(); break; case 5: output(); break; case 6: clear(); break; default:cout退出:n;system(cls);break; class Bookprivate: int tag; int number; char name20; int onshelf;public: Book() char *getname() return name; int getnumber() return number; int gettag() return tag; void setname(char na) strcpy(name,na); void delbook() tag=1; void addbook(int n,char *na) tag=0; number=n; strcpy(name,na); onshelf=1; int borrowbook()/借书操作 if (onshelf=1) onshelf=0; return 1; return 0;void retbook()/还书操作 onshelf=1;void output()/输出图书 cout setw(6) number setw(18) name setw(10) (onshelf=1? 在架:已借) endl; class BDatabaseprivate: int top; Book bookMaxb; /图书记录 public: BDatabase()/构造函数,将book.txt读到book中 Book b; top=-1; fstream file(book.txt,ios:in);while (1) file.read(char *)&b,sizeof(b); if (!file) break; top+; booktop=b; file.close(); void clear() top=-1;int addbook(int n,char *na) Book *p=equal(n);if (NULL=p) top+; booktop.addbook(n,na); return 1;return 0;Book *equal(int bookid) for (int i=0;i=top;i+) if (booki.getnumber()=bookid &booki.gettag()=0) return &booki; return NULL;void bookdata();void output() for (int i=0;i=top;i+) if (booki.gettag()=0) booki.output();BDatabase()/析构函数,将book写到book.txt文件中 fstream file(book.txt,ios:out); for (int i=0;i=top;i+) if (booki.gettag()=0) file.write(char *)&booki,sizeof(booki); file.close();void BDatabase:bookdata()char choice; char bname40; int bookid;Book *b;while (choice!=0) cout n; cout 图书 维 护 n; cout n; cout 1.新 增 n; cout n; cout 2.更 改 n; cout n; cout 3.删 除 n; cout n; cout 4.查 找 n; cout n; cout 5.显 示 n; cout n; cout 6.全 删 n; cout n; cout 0.退出 n; cout choice;switch (choice) case 1: cout 输入图书编号: bookid; cout 输入图书书名: bname; addbook(bookid,bname); break;case 2: cout 输入图书编号: bookid; b=equal(bookid); if (b=NULL) cout 该图书不存在 endl; break; cout 输入新的书名: bname; b-setname(bname); break;case 3: cout 读入图书编号: bookid; b=equal(bookid); if (b=NULL) cout 该图书不存在 delbook(); break;case 4: cout 读入图书编号: bookid; b=equal(bookid); if (b=NULL) cout 该图书不存在output(); break;case 5: output(); break;case 6: clear(); break; default:cout退出n; system(cls); break;void main() char choice; int bookid,Studentid; RData StudentDB; Student *r; BDatabase BookDB; Book *b; while(choice!=0) cout n; cout 图 书 管 理 系 统 n; cout n; cout 1.借书 n; cout n; cout 2.还书 n; cout n; cout 3.图书维护 n; cout n; cout 4.读者维护 n; cout n; cout 0.退出 n; cout choice; switch (choice) case 1: system(cls); cout Studentid; cout bookid; r=StudentDB.equal(Studentid);/按编号查找 if (NULL=r) cout 不存在该读者,不能借书 endl; break; b=BookDB.equal(bookid); if (b=NULL) cout 不存在该图书,不能借书borrowbook()=0) cout 该图书已借出,不能借书borrowbook(b-getnumber();system(cls);break;case 2: system(cls); coutStudentid; cout bookid; r=StudentDB.equal(Student
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025广西柳州市柳江区应急管理局招聘机关文员和消防队员3人模拟试卷及完整答案详解
- 2025湖南湘西古丈县教育类事业单位公开引进高层次急需紧缺人才6人考前自测高频考点模拟试题及答案详解(必刷)
- 2025广东清远市清城区公路事务中心招聘1人考前自测高频考点模拟试题及答案详解(历年真题)
- 2025年度福建省血液中心招聘6人模拟试卷有完整答案详解
- 2025年福建省南安市龙泉中学招聘15人模拟试卷及答案详解1套
- 2025广西百色市西林县发展和改革局公开招聘3人考前自测高频考点模拟试题及答案详解(有一套)
- 2025辽宁鞍山市海城市人力资源和社会保障服务中心、海城市响堂街道办事处公益性岗位招聘5人模拟试卷及一套答案详解
- 2025年安徽中医药大学招聘教学、科研人员37人模拟试卷含答案详解
- 2025北京建筑大学附属中学第二批招聘教师3人考前自测高频考点模拟试题及一套参考答案详解
- 2025年河南红旗渠(集团)有限责任公司招聘7人模拟试卷附答案详解(模拟题)
- 2025年AI技术在项目管理中的应用洞察报告
- 胃肠外科医生进修汇报
- 慢病健康宣教课件
- 糖尿病患者健康教育讲座
- 青春期生理健康课
- 2025年铁路线路工高级技师练习题库(答案+解析)
- 生产领班的工作职责
- DB44T 2603-2025 预制菜术语及分类
- 磁器口教学课件
- DB4201T 632-2021 岩溶地区勘察设计与施工技术规程
- 2025年高考真题-政治(湖南卷) 含答案
评论
0/150
提交评论