c语言编写图书管理系统程序_C语言图书管理系统

c语言编写图书管理系统程序_C语言图书管理系统DOS界面的图书管理系统,具体内容如下程序分为两块:管理员操作(收录图书、删除图书等)和会员操作(注册、借书、还书等);1、管理员操作界面2、会员操作界面global.h头文件:(程序中只使用了一个编写的头文件,在这里存放了所有的接口函数以及需要使用到的头文件,还有结构体的定义)#include”iostream”#include”string”#include”fstream”#inclu…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

DOS界面的图书管理系统,具体内容如下

程序分为两块:管理员操作(收录图书、删除图书等)和会员操作(注册、借书、还书等);

1、管理员操作界面

2、会员操作界面

global.h头文件:(程序中只使用了一个编写的头文件,在这里存放了所有的接口函数以及需要使用到的头文件,还有结构体的定义)

#include “iostream”

#include “string”

#include “fstream”

#include “conio.h” //getch();

#include “algorithm” //sort();

using namespace std;

#define Max_BookNum 10240 //最大存书数目

#define Max_MemberNum 10240 //最大会员数目

typedef enum{//图书借阅状态

Borrowed=1,//已被借阅

available=0 //当前可借

}Book_Status;

typedef struct{//图书信息

char name[20]; //书名

char author[20]; //作者

string isbn; //图书编号

string price; //价格

string pub; //出版社

string pubtime; //出版时间

string addtime; //收录日期

string Class; //分类号

Book_Status Book_sta; //借阅状态,初始化为可借

}Book_Message;

typedef struct{//借阅人信息

string name; //姓名

string sex; //性别

string number; //学号

char login[20]; //登录号 以A1001开始

char code[20]; //登录密码

Book_Message Borrow_Book[10]; //最大可借书本数目:10本

int BorBook_Cnt; //借书数量

}Member_Message;

void Show_WelMenu(); //Welcome菜单

void Book_InfoInput(); //图书信息录入

void Book_InfoShow(Book_Message *Book_Info); //输出图书信息

void Book_Search(); //搜索书本 0,按书名;1,按作者

void Book_Delete(); //删除图书信息

void Book_InfoChange(); //修改图书信息

void Book_Sort(); //图书排序

void Book_RecordSave(); //图书信息保存

int Book_RecordLoad(); //读档

void Admin_Login(); //管理员登录

void Member_WelMenu(); //会员菜单界面

void Book_WelMenu(); //管理员菜单界面

void Member_Login(); //会员登录

void Member_Reg(); //会员注册

void Member_Bor(); //借书手续

void Member_Ret(); //还书

void Member_Search(); //会员资料查询 0,按姓名;1,按学号

void Member_Delete(); //会员资料注销

void Member_RecordSave();//会员信息保存

int Member_RecordLoad();//会员信息读档

void Member_InfoChange();

//void Member_BookMsgSave();

//int Member_BookMsgLoad();

void Member_MsgShow(Member_Message *Member_Msg);//信息显示

void Member_CodeAdjust();//会员修改密码

主程序:main.c文件:

#include “global.h”

int Book_Record=0;

int Member_Record=0;

Book_Message Book_List[Max_BookNum]; //图书登记表

Member_Message Member_List[Max_MemberNum]; //会员登记表

int main()

{

char key[2];

while(1){

Show_WelMenu();

int cmd;

cin>>cmd;

if(!cmd)

Admin_Login(); //进入管理员登录界面

else

Member_Login(); //进入会员登录界面

cout<

cin>>key;

if(strcmp(key,”y”)==0)

break;

}

cout<

getch();

return 0;

}

以下分别是各个功能模块的函数实现:

1、输出界面(选择登录界面)

void Show_WelMenu()

{

system(“cls”);

cout<

cout<

cout<

}

2、管理员登录程序(这里选择了固定密码登录,Init_Code就是初始密码。当然也可以自行修改密码)

void Admin_Login()

{

short count=0;

char code[20];

char Init_Code[10]=”0″;

cout<

while(1){

cin>>code;

if(strcmp(code,Init_Code)==0){

break;

}

else{

cout<

count++;

if(count>3){

cout<

break;

}

}

}

Book_WelMenu(); //enter Admin Menu

}

3、会员登录程序(使用账户密码登录,若无账号,可自行注册)

void Member_Login()

{

Book_Record = 0;

Member_Record = 0;

Book_Record = Book_RecordLoad();

Member_Record = Member_RecordLoad(); //从文件读入当前注册表

char code[20],login[20],Req[2];

bool Login_Sta = false;

while(1){ //登录程序,登录成功后退出

if(Login_Sta) break;

if((Member_Record==0)){

cout << “\t\t\t\t用户库为空,请先注册” << endl;

cout << “\t\t\t\t按任意键注册”;

getch();

system(“cls”);

Member_Reg();

}

else{

cout << “\t\t\t\t请输入会员登录号:” << endl;

cin>>login;

for(Mem_Point=0; Mem_Point

if((strcmp(login,Member_List[Mem_Point].login) == 0)){

cout << “\t\t\t\t请输入密码:” << endl;

cin >> code;

while(strcmp(code,Member_List[Mem_Point].code) != 0){

cout << “密码错误,请重新输入” << endl;

cin >> code;

}

Login_Sta = true;

cout << “\t\t\t\t登录成功,按任意键继续”;

break;

}

}

if(Mem_Point >= Member_Record){

cout << “\t\t\t该用户未注册,不能使用图书管理系统” << endl;

cout << “\t\t\t\t是否现在注册(Y/N)” << endl;

cin >> Req;

if((strcmp(Req,”y”) == 0) || (strcmp(Req,”Y”) == 0))

Member_Reg();

}

}

}

getch();

system(“cls”);

Member_WelMenu();

getch();

}

4、文件操作(读入与写入,这里只贴出会员信息部分的文件操作,图书收录的文件操作类似)

/*导出会员注册表到文件*/

void Member_RecordSave()

{

ofstream outfile;

outfile.open(“E:\\Course\\002\\Member_Info.txt”,ios::ate|ios::out); //若有文件,先清空,再写入

for(int i=0;i

outfile << Member_List[i].name <

<< Member_List[i].login <

}

outfile.close();

}

/*从文件导入会员注册表*/

int Member_RecordLoad()

{

int Member_FileLoad=0;

ifstream infile;

infile.open(“E:\\Course\\002\\Member_Info.txt”,ios::in);

string n,s,num;

char l[20],c[20];

while(1){

infile >> n >> s >> num >> l >> c; //从文件导入信息,并注册会员信息

Member_Add(n,num,l,c);

if(infile.eof() != 0)break;

Member_FileLoad++;

}

infile.close();

return Member_FileLoad;

}

5、会员注册程序(先扫描注册表,若已被注册返回失败。注册就是在文件中添加会员信息)

//内部函数

void Member_Add(string n,string s,string num,char* l,char* c)

{

Member_List[Member_Record].name = n;

Member_List[Member_Record].sex =s;

Member_List[Member_Record].number =num;

strcpy(Member_List[Member_Record].login,(const char*)l);

strcpy(Member_List[Member_Record].code,(const char*)c);

Member_Record++;

}

/*会员注册程序*/

void Member_Reg()

{

string n,c[20],choice[2];

cout << “\t\t\t\t会员注册” << endl;

cout << “\t\t请以此输入 姓名、性别、学号、登录号、密码” << endl;

cin >> n >> s >> num >> l >> c;

for(int i=0; i

if(strcmp(Member_List[i].login,l) == 0){

cout << “\t\t\t\t该登录号已存在,注册失败” << endl;

getch();

system(“cls”);

return;

}

}

Member_Add(n,c);

cout << “\t\t\t\t注册成功” << endl;

cout << “\t\t\t\t是否存入文件\ty/n?” << endl;;

cin >> choice;

if((strcmp(choice,”y”)==0) || (strcmp(choice,”Y”) == 0))

Member_RecordSave();

getch();

system(“cls”); //clear screan

}

6、会员注销和密码修改

/*会员资料注销*/

void Member_Delete()

{

bool key=false;

char Del_Name[20],cmd[2];

cout<

cin>>Del_Name;

for(int i=0;i

if(strcmp(Member_List[i].login,Del_Name)==0){ //found

key=true;

Member_MsgShow(&Member_List[i]);

cout<

cin>>cmd;

if((strcmp(cmd,”y”)==0)||(strcmp(cmd,”Y”)==0)){ //ensure delete

while(i<=Member_Record-1){

Member_List[i]=Member_List[i+1];

i++;

}

Member_Record–;

Member_RecordSave();

cout<

break;

}

}

}

if(!key) cout<

}

void Member_CodeAdjust()

{

char TempCode[20],choice[2],Temp[20];

strcpy(Temp,Member_List[Mem_Point].code);

while(1){

cout<

cin>>TempCode;

if(strcmp(Temp,TempCode)==0){

cout<

cin>>TempCode;

cout<

strcpy(Member_List[Mem_Point].code,TempCode);

cin>>TempCode;

if(strcmp(Member_List[Mem_Point].code,TempCode)==0){

cout<

Member_RecordSave();

break;

}

else{

cout<

cout<

cin>>choice;

if((strcmp(choice,”n”)==0)||(strcmp(choice,”N”)==0))

return ;

continue;

}

}

cout<

getch();

}

}

管理员操作的大部分程序和会员操作是类似的,这里只贴一个图书排序的操作

7、图书排序

/* 内部函数,供图书排序功能调用*/

bool cmp( Book_Message a,Book_Message b ){

if(strcmp( a.author,b.author ) == 0)

return strcmp( a.name,b.name ) < 0;

return strcmp( a.author,b.author ) < 0;

}

/*

* @brief 图书排序,根据作者姓名升序排序,若作者相同,则按书名升序排序

* @param None

* @retval None

*/

void Book_Sort()

{

sort( Book_List,Book_List+Book_Record,cmp );

cout << “排序已完成” << endl;

cout << “所有图书信息如下” << endl;

cout << “书名\t作者\t价格\t出版社\t出版时间\t分类号 编号 收录日期 是否可借” << endl;

for(int i=0; i

Book_InfoShow( &Book_List[i] );

}

getch();

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程小技巧。

总结

以上是编程之家为你收集整理的C语言图书管理系统简洁版全部内容,希望文章能够帮你解决C语言图书管理系统简洁版所遇到的程序开发问题。

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

小编个人微信号 jb51ccc

喜欢与人分享编程技术与工作经验,欢迎加入编程之家官方交流群!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/183180.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • Java ListNode 链表

    JavaListNode链表基本结构基本初始化添加构造方法初始化范型写法创建与遍历链表插入节点替换节点删除节点补充说明基本结构链表是一种数据结构,由数据和指针构成,JavaListNode链表是一种由Java自定义实现的链表结构。基本初始化classListNode{//类名:Java类就是一种自定义的数据结构intval;//数据:节点数据ListNodenext;//对象:引用下一个节点对象。在Jav

  • spssk均值聚类报告_K均值聚类

    spssk均值聚类报告_K均值聚类机器学习中的k均值聚类属于无监督学习,所谓k指的是簇类的个数,也即均值向量的个数。算法初始状态下,要根据我们设定的k随机生成k个中心向量,随机生成中心向量的方法既可以随机从样本中抽取k个样本作为中心向量,也可以将中心向量固定在样本的维度范围之内,避免中心向量过偏远离大多数样本点。然后每个样本点需要与k个中心向量分别计算欧氏距离,取欧氏距离最小的中心向量作为该样本点的簇类中心,当第一轮迭代完成之后,…

    2022年10月28日
  • 队列数据结构的典型应用_kafka优先级队列

    队列数据结构的典型应用_kafka优先级队列上一篇文章讲解了队列的相关知识,同时用代码实现了一个队列结构。那么本文将介绍一下另一种特殊的队列结构,叫做优先级队列。上一篇文章的跳转链接——公众号:Lpyexplore的编程小屋关注我,每天更新,带你在python爬虫的过程中学习前端,还有更多电子书和面试题等你来拿数据结构——优先级队列一、什么是优先级队列一、什么是优先级队列在了解了什么是队列以后,我们再来了解优先级队列,顾名思义,优先级队列就是在队列的基础上给每个元素加上了先后顺序,我们仍然拿排队买票的例子来讲解。…

  • 高并发解决方案之一 ——负载均衡

    高并发解决方案之一 ——负载均衡1.什么是负载均衡?当一台服务器的性能达到极限时,我们可以使用服务器集群来提高网站的整体性能。那么,在服务器集群中,需要有一台服务器充当调度者的角色,用户的所有请求都会首先由它接收,调度者再根据每台服务器的负载情况将请求分配给某一台后端服务器去处理。那么在这个过程中,调度者如何合理分配任务,保证所有后端服务器都将性能充分发挥,从而保持服务器集群的整体性能最优,这就是负载均衡问题。下…

  • 机器学习算法(一):逻辑回归模型(Logistic Regression, LR)[通俗易懂]

    机器学习算法(一):逻辑回归模型(Logistic Regression, LR)[通俗易懂]线性分类器:模型是参数的线性函数,分类平面是(超)平面;非线性分类器:模型分界面可以是曲面或者超平面的组合。典型的线性分类器有感知机,LDA,逻辑斯特回归,SVM(线性核);典型的非线性分类器有朴素贝叶斯(有文章说这个本质是线性的,http://dataunion.org/12344.html),kNN,决策树,SVM(非线性核)https://www.cnblogs.com/sparkw…

  • Android EdtiText 添加表情

    Android EdtiText 添加表情

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号