C++实现图书管理系统课程设计

大一C++课设,没有用分文件的形式,只是把菜单页面单独分开了。用的是链表,都是一些基础的东西。另外采用了二维数组来保存读者借书信息,并将二维数组读入文件中。

菜单:#pragmaoncevoid_mainmenu();voidLoginmenu();voidRegistmenu();voidreadermenu();voidmangermenu();voidchangebookmenu();voidbrowsemenu();菜单文件`#include“menu.h”

void_mainmenu(){

voidRegistmenu(){printf(“注册页面\n”);printf(“**\n”);printf(“1.管理员注册\n”);printf(“\n”);printf(“2.用户注册\n”);printf(“\n”);printf(“3.返回\n”);printf(“\n”);printf(“4.退出\n”);printf(“**\n”);printf(“请按键选择:”);}

voidreadermenu(){printf(“用户页面\n”);printf(“**\n”);printf(“1.借书\n”);printf(“\n”);printf(“2.还书\n”);printf(“\n”);printf(“3.浏览图书信息\n”);printf(“\n”);printf(“4.查看已借阅书籍\n”);printf(“\n”);printf(“5.修改密码\n”);printf(“\n”);printf(“6.返回\n”);printf(“\n”);printf(“7.退出\n”);printf(“**\n”);printf(“请按键选择:”);}

voidmangermenu(){printf(“管理员页面\n”);printf(“**\n”);printf(“1.增加图书\n”);printf(“\n”);printf(“2.删除图书\n”);printf(“\n”);printf(“3.修改图书信息\n”);printf(“\n”);printf(“4.查看读者信息\n”);printf(“\n”);printf(“5.浏览图书信息\n”);printf(“\n”);printf(“6.修改密码\n”);printf(“\n”);printf(“7.返回\n”);printf(“\n”);printf(“8.退出\n”);printf(“**\n”);printf(“请按键选择:”);}

voidchangebookmenu(){printf(“\n\n”);printf(“\t\t\t\t*\n”);printf(“\t\t\t\t1.修改id号\n”);printf(“\t\t\t\t\n”);printf(“\t\t\t\t2.修改图书名称\n”);printf(“\t\t\t\t\n”);printf(“\t\t\t\t3.修改图书作者\n”);printf(“\t\t\t\t\n”);printf(“\t\t\t\t4.修改出版社\n”);printf(“\t\t\t\t\n”);printf(“\t\t\t\t5.修改图书数量\n”);printf(“\t\t\t\t\n”);printf(“\t\t\t\t6.修改是否可借\n”);printf(“\t\t\t\t\n”);printf(“\t\t\t\t7.返回\n”);printf(“\t\t\t\t*“);printf(“\n\n”);}

voidbrowsemenu(){printf(“\n\n\n\n”);printf(“\t\t\t\t*\n”);printf(“\t\t\t\t1.按id号浏览\n”);printf(“\t\t\t\t\n”);printf(“\t\t\t\t2.按图书数量浏览\n”);printf(“\t\t\t\t\n”);printf(“\t\t\t\t3.返回\n”);printf(“\t\t\t\t\n”);printf(“\t\t\t\t4.退出\n”);printf(“\t\t\t\t*\n”);printf(“请按键选择:”);}主程序#define_CRT_SECURE_NO_WARNINGS

usingnamespacestd;classUser{protected:characcount[20];charpassword[20];charspassword[20];

public:virtualvoidLogin()=0;virtualvoidRegist()=0;virtualvoidsave()=0;virtualvoidBrowseBook()=0;virtualvoidChangePassword()=0;virtualvoidFindPassword()=0;};

classReader:publicUser{private:intnumber;stringname;stringsex;intbooks;//借书数量intbookcnt;//借阅次数charbooklist[20][20];//储存借阅书籍classReader*next;

public:virtualvoidLogin();virtualvoidRegist();virtualvoidsave();virtualvoidBrowseBook();virtualvoidChangePassword();virtualvoidFindPassword();voidcreat();voidBrowseBorrowBook(Readerpp);voidBorrowBook(Readerpp);voidReturnBook(Reader*pp);

public:voidset_number(int_number){number=_number;};voidset_name(string_name){name=_name;};voidset_sex(string_sex){sex=_sex;};voidset_next(Readerp){next=p;};voidset_books(int_books){books=_books;};voidset_bookcnt(int_bookcnt){bookcnt=_bookcnt;};intget_bookcnt(){returnbookcnt;};intget_number(){returnnumber;};intget_books(){returnbooks;};Readerget_next(){returnnext;}stringget_name(){returnname;};stringget_sex(){returnsex;};charget_account(Readerp){returnp->account;};charget_password(Readerp){returnp->password;};charget_spassword(Readerp){returnp->spassword;};charget_booklist(Readerp,inti){returnp->booklist[i];};

};

classManger:publicUser{private:classManger*next;

public:

public:voidset_next(Mangerp){next=p;};Mangerget_next(){returnnext;};charget_account(Mangerp){returnp->account;};charget_password(Mangerp){returnp->password;};charget_spassword(Mangerp){returnp->spassword;};};

classBook{private:intid;intamount;intflag;stringbookname;stringauthor;stringpress;classBook*next;

};

classDBFile{public:voidcls();voidover();voidlogin();voiduseLogin(Userbase);voidregist();voiduseRegist(Userbase);voidusebrowsebook(Userbase);voidusesave(Userbase);voidusechangepassword(Userbase);voidusefindpassword(Userbase);voidfindpassword();intexist(characconut,intflag);void_main();voididsort();voidbookamountsort();voidshowidsort();voidshowbookamountsort();voidmangerfunction();voidreaderfunction(Readerrp);};Readerrhead=NULL;Reader_rend=NULL;Mangermhead=NULL,mend=NULL;Bookbhead=NULL;Bookbend=NULL;charcode[20]=“glysw”;

//读者类voidReader::Login(){intcnt=4;intflag=0;intk=0;inti;charc;DBFilefp=newDBFile;Readerp=rhead->get_next();charrpassword[2000];charraccount[2000];cout<<“\n\n\n\n\n\n\n”;printf(“请输入您的账户(按0退出):”);while(cin>>raccount){if(strcmp(raccount,“0”)==0){return;}if(strlen(raccount)<=16){break;}else{cout<<“请输入长度为1到16位的账户:”;}}

}

voidReader::Regist(){DBFilefp=newDBFile;Readerrp=newReader;charraccount[2000];charrpassword[2000];charrspassword[2000];charname[200];charsex[10];intnumber;

}voidReader::save(){Reader*rp=rhead->get_next();ofstreamf_reader(“reader.txt”,ios::out);while(rp){f_reader<account<<““<password<<““<spassword<<““<number<<““<name<<““<sex<<““<bookcnt<<““<books;for(inti=0;ibookcnt;i++){f_reader<<““<get_next();}f_reader.close();}

voidReader::BorrowBook(Readerpp){Bookbp=bhead->get_next();Book*_bp=newBook;_bp->show_book();charbookname[200];intamount;intflag=1;intsign=1;intexist=0;

//数据操作类voidDBFile::cls(){system(“cls”);}voidDBFile::over(){DBFile*dbp=newDBFile;dbp->cls();system(“color6”);inttime=6;printf(“\n\n\n\n\n\n\n\n\n”);printf(“\t\t\t\t\t\t感谢您的使用!!\n\n\n\n\n”);printf(“程序即将关闭…”);while(—time>=1){printf(“\r%d”,time);printf(“\b”);Sleep(1000);}dbp->cls();exit(0);}

voidDBFile::login(){Readerrp=newReader;Mangermp=newManger;intsign=0;while(1){cls();Loginmenu();charchoose=_getch();switch(choose){case‘1’:cls();useLogin(mp);break;case‘2’:cls();useLogin(rp);break;case‘3’:cls();sign=1;break;case‘4’:cls();over();break;default:cout<<“输入无效!!”;break;}if(sign){break;}}}voidDBFile::useLogin(Userbase){base->Login();}voidDBFile::regist(){Readerrp=newReader;Mangermp=newManger;intsign=0;while(1){cls();Registmenu();charchoose=_getch();switch(choose){case‘1’:cls();useRegist(mp);break;case‘2’:cls();useRegist(rp);break;case‘3’:cls();sign=1;break;case‘4’:cls();over();break;default:cout<<“无效输入!!”;break;}if(sign){break;}}}voidDBFile::usesave(Userbase){base->save();}voidDBFile::usechangepassword(User*base){base->ChangePassword();}

voidDBFile::useRegist(User*base){base->Regist();}

voidDBFile::usebrowsebook(User*base){base->BrowseBook();}

voidDBFile::usefindpassword(Userbase){base->FindPassword();}voidDBFile::findpassword(){printf(“\n\n\n\n\n\n”);printf(“\t\t\t\t\t**\n”);printf(“\t\t\t\t\t\n”);printf(“\t\t\t\t\t1.管理员找回密码\n”);printf(“\t\t\t\t\t\n”);printf(“\t\t\t\t\t2.用户找回密码\n”);printf(“\t\t\t\t\t\n”);printf(“\t\t\t\t\t3.返回\n”);printf(“\t\t\t\t\t\n”);printf(“\t\t\t\t\t**\n”);printf(“请按键选择:”);intchoose;intsign=0;Readerrp=newReader;Manger*mp=newManger;scanf(“%d”,&choose);while(1){cls();

}intDBFile::exist(characcount,intflag){if(flag==0){Readerp=rhead->get_next();while(p!=NULL){if(strcmp(account,p->get_account(p))==0){return1;}p=p->get_next();}}elseif(flag==1){Manger*p=mhead->get_next();while(p!=NULL){if(strcmp(account,p->get_account(p))==0){return1;}p=p->get_next();}}return0;}voidDBFile::_main(){while(1){cls();_mainmenu();charchoose=_getch();switch(choose){case‘1’:cls();login();break;case‘2’:cls();regist();break;case‘3’:cls();findpassword();break;case‘4’:cls();over();break;default:cout<<“无效输入!!”;break;}}}

}voidManger::BrowseBook(){DBFilefp=newDBFile;intsign=0;while(1){fp->cls();browsemenu();charchoose=_getch();switch(choose){case‘1’:fp->cls();fp->showidsort();break;case‘2’:fp->cls();fp->showbookamountsort();break;case‘3’:fp->cls();sign=1;break;case‘4’:fp->cls();fp->over();break;default:break;}if(sign){break;}}}voidManger::save(){Mangermp=mhead->get_next();ofstreamf_manger(“manger.txt”,ios::out);while(mp){f_manger<account<<““<password<<““<spassword<get_next();}f_manger.close();}voidManger::creat(){characcount[20];charpassword[20];charspassword[20];

}voidManger::AddBook(){DBFilefp=newDBFile;Bookp=bhead->get_next();inta;intid=0;intamount;charbookname[2000];do{fp->cls();cout<<“\n\n\n\n\n”;cout<<“请输入要添加书名id(按0退出):”;while(cin>>id){if(id==0){return;}if(id<0){cout<<“请输入正确格式的id号(按0退出):”;}else{break;}}intflag=0;while(p){if(p->get_id()==id){flag=1;break;}p=p->get_next();}if(flag){cout<<“已查出此书,请输入再次增加图书的数量:”;while(cin>>amount){if(amount<=199&&amount>0){inttemp=p->get_amount()+amount;p->set_amount(temp);cout<<“图书”<get_bookname()<<“添加成功!”;

}voidManger::ChangeBook(){DBFilefp=newDBFile;Bookp=bhead->get_next();intid;intamount;intflag=0;charbookname[200];charauthor[200];charpress[200];intexist=0;intsign=0;

}voidManger::DeleteBook(){Bookbp=bhead->get_next();charbookname[20];intflag=0;bp->show_book();cout<<“请输入您要删除图书的名称(按0退出):”;while(cin>>bookname){if(strcmp(bookname,“0”)==0){return;}while(bp){if(bp->get_bookname()==bookname){flag=1;break;}bp=bp->get_next();}if(flag==0){cout<<“未查询到此书!\n”<<“请重新输入(按0退出):”;bp=bhead->get_next();}else{break;}}DeleteReaderBook(bookname);bp=bhead->get_next();Bookpp=bhead;while(bp){//bp->next可能是链表的最后一个if(bp->get_bookname()==bookname){if(bp->get_next()==NULL){bhead->set_next(NULL);}else{pp->set_next(bp->get_next());}}pp=pp->get_next();bp=bp->get_next();}

}voidManger::DeleteReaderBook(charbookname){Readerrp=rhead->get_next();Reader*pp=newReader;intflag=0;

}voidManger::BrowseReader(){

//图书类voidBook::creat()

{ifstreamf_book(“book.txt”,ios::in);intid;intamount;intflag;stringbookname;stringauthor;stringpress;while(f_book>>id&&f_book>>flag&&f_book>>amount&&f_book>>bookname&&f_book>>author&&f_book>>press){Book*p=newBook;p->id=id;p->flag=flag;p->amount=amount;p->bookname=bookname;p->author=author;p->press=press;

voidBook::save(){Book*bp=bhead->get_next();ofstreamf_book(“book.txt”,ios::out);while(bp){f_book<id<<““<flag<<““<amount<<““<bookname<<““<author<<““<press<get_next();}f_book.close();}

voidBook::show_book(){Book*bp=bhead->get_next();cout<<“id号\t\t”<<“是否可借\t\t”<<“数量\t\t”<<“书名\t\t”<<“作者\t\t”<<“出版社\n”;while(bp){cout<get_id()<<“\t\t”<get_flag()<<“\t\t\t”<get_amount()<<“\t\t”<get_bookname()<<“\t\t”<get_author()<<“\t\t”<get_press()<<“\n”;bp=bp->get_next();}}intmain(){mhead=newManger;mend=newManger;mhead->set_next(NULL);mend=mhead;

THE END
1.图书管理系统设计与实现—看这篇就够了图书管理系统设计与实现 图书馆人员结构复杂,人员数量有限,涉及方面很广,如果还使用手工操作处理图书借阅问题,工作将非常繁琐,需要大量的人力、物理、财力,极大的浪费了资源,对于图书管理人员来说,图书馆管理包括图书信息管理、图书类别管理、借阅信息管理、管理员信息管理等等。而这些项目在过去靠手工操作,需要手工记录这些https://zhuanlan.zhihu.com/p/626238891
2.图书馆信息管理系统——数据库原理课程设计(E课程要求:根据题目作需求分析,进行概念结构设计,绘制E-R图。进行逻辑结构设计,确定数据库模式,并优化。利用SQL Server创建数据库及数据表,录入数据。设计调试数据管理功能及查询功能,撰写课程设计报告。1.数据库的需求分析并设计概念结构 1.1 需求分析 本系统主要实现对图书馆信息的管理,主要可以分为两大块https://baijiahao.baidu.com/s?id=1730518039414180561&wfr=spider&for=pc
3.数据库课程设计实验报告图书馆管理系统图书馆信息管理系统数据库用以收集、存储书籍信息、人员(读者、图书管理员)信息、图书借阅信息以及意外处理信息,及时记录存储各个环节信息的变更,以便管理、查询、显示、输出,节约大量人力物力把人们从繁杂的手工记录方式中解脱出来的同时,有力保障图书馆日常事务的高效运作。 https://blog.csdn.net/xiedelong/article/details/79483427
4.原创网上书店销售管理系统课程设计报告b) 图书基本信息管理:图书基本信息录入、维护与查询。 c) 订单基本信息管理:订单基本信息录入、维护与查询。 d) 配送基本信息管理:配送基本信息录入、维护与查询。 e) 出版社基本信息管理:出版社基本信息录入、维护与查询。 图3-1 网上书店销售系统功能图 https://www.jianshu.com/p/e6167aff52ef
5.Java/SSM/LayUIJavaEE课程设计(基于Layui+SSM的图书管理系统JavaEE课程设计(基于Layui+SSM的图书管理系统) 一、项目介绍 二、技术栈 三、项目结构 (一)数据库 1、管理员表(admin) 2、图书类型表(type_info) 3、图书信息表(book_info) 4、读者信息表(reader_info) 5、借阅信息(lend_list) 6、公告管理(notice) https://blog.51cto.com/u_14210396/6246333
6.图书管理系统设计与实现—看这篇就够了腾讯云开发者社区图书管理系统设计与实现 图书馆人员结构复杂,人员数量有限,涉及方面很广,如果还使用手工操作处理图书借阅问题,工作将非常繁琐,需要大量的人力、物理、财力,极大的浪费了资源,对于图书管理人员来说,图书馆管理包括图书信息管理、图书类别管理、借阅信息管理、管理员信息管理等等。而这些项目在过去靠手工操作,需要手工记录这些https://www.cloud.tencent.com/developer/article/1697988
7.Java图书管理系统,课程设计必用(源码+文档)javaJava图书管理系统,课程设计必用(源码+文档)更新时间:2021年06月30日 15:22:21 作者:初尘屿风 本系统采用Java,MySQL 作为系统数据库,重点开发并实现了系统各个核心功能模块,包括采编模块、典藏模块、基础信息模块、流通模块、期刊模块、查询模块、评论模块、系统统计模块以及帮助功能模块https://www.jb51.net/article/216374.htm
8.电子图书馆(图书借阅系统):图书借阅管理的功能模块根据登录人员1.1 课程设计题目 随着互联网的发展,在线管理系统日益完善。生活中读者借阅图书,管理员在线管理图书信息,使网络与人们的生活息息相关。在线系统方便了图书管理,真正使信息得以共享,改变了人们的工作和生活方式。在线管理图书是图书馆提高工作效率的有效方式,同时也为读者们借阅图书的提供了有力保障。在读书氛围浓厚的今天https://gitee.com/hehe8/library
9.数据库课程设计报告—图书借阅管理系统.doc数据库课程设计报告—图书借阅管理系统,数据库课程设计报告(一) ——图书借阅管理系统本报告包含三部分,简要摘录参见下属。本文共42页,1.3万余字系统概述图书馆管理系统是一些单位不可缺少的部分,书籍是人类不可缺少的精神食粮,尤其对一些学校来说,尤其重要。所以图书馆管理系统应该能够为用户提供充足的信息和快捷的http://www.queshao.com/docs/34523/
10.C++课程设计(简单图书管理系统)6篇(全文)C++课程设计(简单图书管理系统) 第3篇 随着计算机技术的迅猛发展, 很多新的、高效的软件开发技术应运而生。《C++程序设计》就是应潮流与需求而发展起来的一门优秀的程序设计语言, 它受到许多计算机专业人士及程序设计人员的青睐,在很多高等院校中《C++程序设计》都被列为计算机专业教学体系中的一门重要的主干课。但https://www.99xueshu.com/w/fileiuknvdrv.html
11.《管理信息系统》课程设计《管理信息系统》课程设计 随着科学技术的进步和教育体制改革不断深化,实现高校课程多媒体化已经成为高校战略规划中着重研究的课题。本文针对我国高校课程多媒体信息管理系统的功能、系统框架、实践应用等方面进行分析,以期为我国高校课程多媒体信息管理系统的建立与完善提https://www.360wenmi.com/f/filepg5d52re.html
12.2022学院高度重视教育信息化,积极推进校园网络及信息资源建设。学院现有管理信息系统数据总量3070GB、上网课程数20门、电子图书4544册、线上音像视频79小时。通过第三方合作或直接采购第三方信息系统及服务的方式,积极拓展学院的信息资源,信息(资源)安全性更高,信息资源保障更有力。 http://xxgk.witpt.edu.cn/QinDan/JiaoXue/2023/1208/578.html
13.图书馆信息管理系统数据库课程设计VBSQL.docx下载文件名: 图书馆信息管理系统数据库课程设计VBSQL.docx 附件大小: 1 MB 举报本内容 下载通道游客无法下载, 注册 登录 去充值 熟悉论坛请点击新手指南 下载说明 1.下载一个附件只会扣除您一次免流量下载次数或通用积分。 2.论坛支持迅雷和网际快车等p2p多线程软件下载,请在上面选择下载通道单击右健下载即可(不会https://bbs.pinggu.org/a-5046234.html
14.数据结构课程设计数据结构课程设计 图书管理系统 一、需求分析 在进行一个项目的设计之前,先要进行必要的需求分析。 现某图书馆需要管理其各种人员和图书信息,希望实现办公的信息化,通过建立一个图书管理系统来管理图书。其完成的功能如下: (1)可以实现图书的登记、借阅的管理。 http://www.360doc.com/document/20/1002/22/71802450_938578529.shtml
15.关于图书管理员心得体会(精选13篇)第二,在这次课程设计中,我主要承担任务是进行系统的需求分析模块,系统功 能结构设计模块,设计报告的总体完成模块;在分工中,这也是我实际情况出发的。 首先,在系统的需求设计模块中,我和组长认真协调组织,和代码开发人员进行认真协调沟通,根据课程设计任务书的要求,结合课本上的图书信息管理系统案例和图书馆借相关书籍,https://www.fwsir.com/xinde/html/xinde_20230507125650_2804722.html
16.软件工程课程设计——学校图书借阅管理系统专业方向组设计 学校图书借阅管理系统 指导教师 李鑫 院(系、部) 电信学院 专业班级 计算机 06—2 学 号 0606010212 姓 名 宋成龙 电子与信息工程学院 计算机科学系 参考目录 1 问题定义 2 项目背景 https://doc.mbalib.com/view/c33c697a77fd207ec1f042da189adfdd.html
17.数据库系统课程设计图书管理系统程序编写环境:数据管理系统:microsoft office access程序编写平台:microsoft vieual basic.net操作系统:microsoft xp sp2测试用帐号及密码:学生帐号:3264学生密码:888888管理员帐号:admin管理员密码:admin下面子系统是有本人编写的:l 管理员管理系统l 图书管理l 超时管理第二节需求分析数据字典数据库名:library.mdb1)https://m.renrendoc.com/paper/150419309.html
18.图书管理系统数据库课程设计报告书借书证编号 3、总体模块设计: 该系统的全部功能由一个主控界面(两个表单)、一个报表以及相关的四个表 单组成,其总体模块框图如下: 五、模块设计: 1、欢迎界面和主控界面表单的设计: 图书馆信息管理系统的主界面由“欢迎表单”和“主控表单”组成,主控表 单上安排六个命令按钮, 分别实现总体框图中的五部分功能https://www.mayiwenku.com/p-54875419.html
19.山东大学数据库课程设计——在线图书馆管理系统附加实验报告这是用jsp写的一个在线图书馆管理系统,支持读者和图书信息的增删查改,也支持图书的借还等功能,还附加了详细的实验报告。项目和数据库直接分别导入到eclipse和MySQL中就可以用了。注意更改数据库中的密码 代码片段和文件信息 package com;import java.io.IOException;import javax.servlet.Filter;import javax.servlethttp://www.nz998.com/java/220303.html
20.实训报告范文(精选10篇)二、课程设计报告内容 2.1 实训内容 本课程设计的题目是设计一个简化的图书管理系统。该系统从图书馆管理人员的角度出发,实现对图书信息、读者信息的浏览、添加、删除和查询,同时还可以对读者借书、还书过程进行操作和控制。设计内容主要包括系统分析、数据库、数据表的创建、系统各个窗体的布局及其编码实现。 https://mip.ruiwen.com/gongwen/baogao/196686.html