当前位置:首页 > 代码 > 正文

数据结构图书管理系统源代码(数据结构图书馆管理信息系统代码)

admin 发布:2022-12-19 21:37 137


本篇文章给大家谈谈数据结构图书管理系统源代码,以及数据结构图书馆管理信息系统代码对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。

本文目录一览:

数据库图书管理系统代码

create database db

use db

create table 借阅等级信息(

借阅等级 int primary key,

最长借阅时间 int,

最大借阅数量 int,

)

insert into 借阅等级信息 values

(0, 30, 10),

(1, 60, 20),

(2, 90, 30),

(3, 120, 40)

create table 读者信息(

姓名 char(15) not null,

证件号 char(12) primary key,

借阅等级 int default 0,

累计借书 int default 0,

foreign key(借阅等级) references 借阅等级信息(借阅等级)

)

insert into 读者信息(姓名, 证件号, 借阅等级) values

('张三', '541607120165', 1),

('李四', '541707010185', 3),

('王五', '541707120165', 1),

('赵六', '541505980268', 2),

('孙七', '541407010169', 0),

('周八', '541307010489', 1)

create table 出版社信息(

出版社 varchar(20) primary key,

地址 varchar(25),

联系电话 char(7)

)

insert into 出版社信息 values

('清华大学出版社', '北京', '4979421'),

('晟威出版社', '天津', '5564130'),

('南海出版公司', '海南', '4984910'),

('上海文艺出版社', '上海', '6640239')

create table 图书信息(

索书号 char(15) primary key,

作者 char(15),

书名 char(15),

出版社 varchar(20),

出版时间 date,

foreign key(出版社)references 出版社信息(出版社)

)

insert into 图书信息 values

('b12987', '严蔚敏', '数据结构', '清华大学出版社', '2012-02-06'),

('b97894', '东野圭吾', '幻夜', '南海出版公司', '2004-08-02'),

('b16546', '吴玉华', '物理实验教程', '清华大学出版社', '2013-05-15'),

('b89490', '张雪峰', '考研指点', '晟威出版社', '2016-12-12'),

('b56400', '郏宗培', '纸上寻仙记', '上海文艺出版社', '2011-02-05')

create table 单本图书信息(

条码号 char(7) primary key check(len(条码号) = 7),

索书号 char(15),

馆藏地 varchar(40),

书刊状态 varchar(6) check(书刊状态 in ('可借', '借出', '非可借')),

历史借阅量 int default 0,

foreign key(索书号)references 图书信息(索书号)

)

insert into 单本图书信息(条码号, 索书号, 馆藏地, 书刊状态) values

('t987628', 'b97894', '三楼A8', '借出'),

('t594805', 'b97894', '二楼C7', '可借'),

('t984910', 'b89490', '五楼A2', '借出'),

('t940566', 'b12987', '负一楼D3', '借出')

create table 借阅信息(

借阅号 char(6) primary key,

借阅时间 date,

归还时间 date,

图书条码号 char(7),

借阅人证件号 char(12),

foreign key(图书条码号) references 单本图书信息(条码号),

foreign key(借阅人证件号) references 读者信息(证件号)

)

create table 评论信息(

评论号 char(8) primary key,

评分 numeric(2, 1),

内容 varchar(200),

评论时间 date,

评论者id char(12),

索书号 char(15),

foreign key(索书号)references 图书信息(索书号),

foreign key(评论者id)references 读者信息(证件号)

)

insert into 评论信息 values

('p12391', 8.9, '很有趣', '2015-06-24', '541707010185', 'b97894'),

('p98523', 7.8, '受益颇多', '2016-05-22', '541307010489', 'b89490'),

('p94606', 6.8, '完全看不懂orz', '2017-05-02', '541607120165', 'b12987')

create table 主题词信息(

ID char(8) primary key,

类别 char(15),

索书号 char(15),

foreign key(索书号)references 图书信息(索书号)

)

insert into 主题词信息 values

('z64400', '计算机', 'b12987'),

('z95410', '物理', 'b16546'),

('z98500', '考研', 'b89490'),

('z64165', '推理\悬疑', 'b97894'),

('z69850', '仙侠', 'b56400')

use db

go

create trigger trigger1

on 借阅信息

after insert

as

begin 

update 读者信息                                                 --更改读者累计借书量

set 累计借书 = 累计借书 + 1                                   

from 读者信息, inserted

where 读者信息.证件号 = inserted.借阅人证件号

update 单本图书信息                                             --更改图书状态

set 单本图书信息.书刊状态 = '借出'

from inserted, 单本图书信息

where inserted.图书条码号 = 单本图书信息.条码号

update 单本图书信息

set 历史借阅量 = 历史借阅量 + 1                                 --更改图书历史借阅量

from inserted, 单本图书信息

where inserted.图书条码号 = 单本图书信息.条码号

end

insert into 借阅信息 values

('j13488', '2018-05-01', '2018-08-01', 't987628', '541407010169')

insert into 借阅信息 values

('j14910', '2016-12-11', '2017-01-25', 't984910', '541607120165')

insert into 借阅信息 values

('j97890', '2018-05-14', '2018-06-14', 't940566', '541607120165')

go

create view view_1(图书条码, 借阅者姓名, 编号, 借阅时间, 应还时间)

as

select 图书条码号, 姓名, 证件号, 借阅时间, 归还时间

from 借阅信息, 读者信息

where 借阅信息.借阅人证件号 = 读者信息.证件号 and 归还时间 getdate()

go

create view view_2(图书条码, 历史总借阅量)

as

select 条码号, 历史借阅量

from 单本图书信息, 图书信息

where 单本图书信息.索书号 = 图书信息.索书号 and 书名 = '幻夜'

go

create view view_3(类别, 图书条码, 历史总借阅量)

as

select 类别, 条码号, 历史借阅量

from 单本图书信息, 图书信息, 主题词信息

where 主题词信息.索书号 = 图书信息.索书号 and 图书信息.索书号 = 单本图书信息.索书号 and 类别 = '考研'

go

create view view_4(读者编号, 条码, 图书名称, 应还日期)

as

select 借阅人证件号, 图书条码号, 书名, 归还时间

from 单本图书信息, 图书信息, 借阅信息

where 借阅信息.图书条码号 = 单本图书信息.条码号 and 单本图书信息.索书号 = 图书信息.索书号

and 归还时间 getdate() and 借阅人证件号 = '541607120165'

go

create view view_5(读者编号, 图书条码, 图书名称, 借阅日期, 归还日期)

as

select 借阅人证件号, 图书条码号, 书名, 借阅时间, 归还时间

from 单本图书信息, 图书信息, 借阅信息

where 借阅信息.图书条码号 = 单本图书信息.条码号 and 单本图书信息.索书号 = 图书信息.索书号

and 借阅人证件号 = '541607120165'

go

create view view_6(读者编号, 图书名称, 评论时间, 评论内容)

as

select 评论者id, 书名, 评论时间, 内容

from 借阅信息, 单本图书信息, 评论信息, 图书信息

where 借阅信息.图书条码号 = 单本图书信息.条码号 and 单本图书信息.索书号 = 评论信息.索书号

and 评论信息.索书号 = 图书信息.索书号 and 评论者id = '541607120165'

go

create view view_7(出版社名称, 图书名称, 出版时间)

as

select top 100 percent 出版社信息.出版社, 书名, 出版时间

from 出版社信息, 图书信息

where 出版社信息.出版社 = 图书信息.出版社

order by 出版时间 asc

--执行

select * from view_1

select * from view_2

select * from view_3

select * from view_4

select * from view_5

select * from view_6

select * from view_7 order by 出版时间 asc

扩展资料:

数据库模型:

对象模型

层次模型(轻量级数据访问协议)

网状模型(大型数据储存)

关系模型

面向对象模型

半结构化模型

平面模型(表格模型,一般在形式上是一个二维数组。如表格模型数据Excel)

架构

数据库的架构可以大致区分为三个概括层次:内层、概念层和外层。

内层:最接近实际存储体,亦即有关数据的实际存储方式。

外层:最接近用户,即有关个别用户观看数据的方式。

概念层:介于两者之间的间接层。

数据库索引

主条目:数据库索引

数据索引的观念由来已久,像是一本书前面几页都有目录,目录也算是索引的一种,只是它的分类较广,例如车牌、身份证字号、条码等,都是一个索引的号码,当我们看到号码时,可以从号码中看出其中的端倪,若是要找的人、车或物品,也只要提供相关的号码,即可迅速查到正确的人事物。

另外,索引跟字段有着相应的关系,索引即是由字段而来,其中字段有所谓的关键字段(Key Field),该字段具有唯一性,即其值不可重复,且不可为"空值(null)"。

例如:在合并数据时,索引便是扮演欲附加字段数据之指向性用途的角色。故此索引为不可重复性且不可为空。

数据库操作:事务

主条目:数据库事务

事务(transaction)是用户定义的一个数据库操作序列,这些操作要么全做,要么全不做,是一个不可分割的工作单位。

事务的并发性是指多个事务的并行操作轮流交叉运行,事务的并发可能会访问和存储不正确的数据,破坏交易的隔离性和数据库的一致性。

网状数据模型的数据结构 网状模型 满足下面两个条件的基本层次联系的集合为网状模型。 1. 允许一个以上的结点无双亲; 2. 一个结点可以有多于一个的双亲。

参考资料来源:百度百科——数据库

数据结构设计图书管理系统

#include stdio.h #include string.h #include stdlib.h // #define MAXSIZE 100 //最大值定义为100 #define LIST_INIT_SIZE 100//图书证使用者最大值定义为100 //借书人的结构体 typedef struct Boro//借书行为 { char BNum[20];//借书的书号 char RetDate[8];//归还日期 struct Boro *next; }Bor; typedef struct LinkBook { Bor *next; //该图书证的借书行为 char CNum[20]; //卡号 int Total; //借书的数量 }lend[LIST_INIT_SIZE];//借书人数组 //图书的结构体信息 typedef struct LNode { char CardNum[20];//图书证号 struct LNode *next; }LinkList; //借书人 typedef struct book {//每种图书需要登记的内容包括书号ISBN、书名、作者、出版社、总库存量和现库存量。 char num[20];//书号 char name[20];//书名 char auth[20];//作者 char pub[20];//出版社 int TotNum;//总库存 int NowNum;//现库存 LinkList *next;//借了该书的人 }ook[MAXSIZE]; // int Retotal;//读者数量 int total; //定义外部变量.书的种类数 // //结构体初始化 void InitBo(ook boo) //初始化图书信息 { for(int i=0;iMAXSIZE;i++) { boo[i].NowNum=0; boo[i].TotNum=0; boo[i].next=NULL; } } void InitRe(lend Lin) //初始化借阅者信息 { for(int i=0;iLIST_INIT_SIZE;i++) Lin[i].next=NULL; } // int mid=0;//外部函数mid,用来返回查找到的位置 bool BinarySearch(ook boo,char SearchNum[]) //二分法查找比较书号 { //用bool函数,但由于函数不能有两个返回值,所以设置一个外部变量mid,用来返回查找到的位置 int low=0,high=total-1; int found=0; while(low=high) { mid=(low+high)/2; //中间点 if(strcmp(boo[mid].num,SearchNum)==0) //书号相同 { found=1; return true; }//查找成功 if(strcmp(boo[mid].num,SearchNum)!=0)//书号不同 high=mid-1; else low=mid+1; } if(found==0) return false; //查找失败 } void Buy(ook boo, char BuyNum[]) {//1、 采编入库:新购入一种书,如果该书在图书账目中已经存在,则将其库存量增加(包 //括总库存量和现库存量),如果该书不存在,则在图书账目中增加一种书,总库存量和现库存量均为1。 if(BinarySearch(boo,BuyNum)) //如果书库中有此书 { boo[mid].TotNum++; //总库存加1 boo[mid].NowNum++; //现库存加1 printf("入库成功.\n"); printf("已更改书库中该书的信息。编号 %s 的书 %s 作者是 %s ,出版社是 %s ,目前的总库存是 %d ,现库存是 %d 。\n",boo[mid].num,boo[mid].name,boo[mid].auth,boo[mid].pub,boo[mid].TotNum,boo[mid].NowNum); } if(!BinarySearch(boo,BuyNum)) { int i; for(i=total;imidtotal;i--) //插在适合位置 保持有序 boo[i]=boo[i-1]; //空出插入位置 printf("该书在书库中不存在。设立新书目,请补全书的详细信息。\n"); strcpy(boo[i].num,BuyNum); printf("该书购入的数量是:"); scanf(" %d",boo[i].NowNum); boo[i].TotNum=boo[i].NowNum; printf("该书的名字是:"); scanf(" %s",boo[i].name); printf("该书的作者是:"); scanf(" %s",boo[i].auth); printf("该书的出版社是:"); scanf(" %s",boo[i].pub);//补全信息 boo[i].next=NULL; total++;//总量+1 printf("已增加该书的信息。编号 %s 的书 %s 作者是 %s ,出版社是 %s ,目前的总库存是 %d ,现库存是 %d 。\n",boo[i].num,boo[i].name,boo[i].auth,boo[i].pub,boo[i].TotNum,boo[i].NowNum); printf("入库成功.\n"); } } void Delete(ook boo,char DeleteNum[]) {//2、 清空库存:某一种书已无保留价值,将它从图书账目中注销。 if(BinarySearch(boo,DeleteNum)==false||total==0) //如果无此书 printf("书库中没有该书.\n"); if(BinarySearch(boo,DeleteNum))//若有 { if(!boo[mid].next) { int j; for( j=mid;jtotal;j++) boo[j]=boo[j+1]; strcpy(boo[j].num,boo[j+1].num); strcpy(boo[j].name,boo[j+1].name); strcpy(boo[j].auth,boo[j+1].auth); strcpy(boo[j].pub,boo[j+1].pub); boo[j].TotNum=boo[j+1].TotNum; boo[j].NowNum=boo[j+1].NowNum; printf("已成功删除该书.\n"); } else printf("该书有借阅者,无法删除。\n"); } } void Borrow(ook boo,lend Lin,char BorrowNum[],char CaNum[]) {//3、 借阅:如果一种书的现库存量大于零,则借出一本书,将现库存量减1, //并登记借阅者的图书证号和归还期限。 Bor *p,*q; LinkList *m,*n; if(!BinarySearch(boo,BorrowNum)||total==0) //如果没有找到此书 printf("书库里没这书。\n");//如果有这书 if(BinarySearch(boo,BorrowNum)) //书库里有 { if(boo[mid].NowNum0) //看现库存是否大于0 { boo[mid].NowNum--;//借出一本,少1 if(boo[mid].next==NULL) //若该书信息下显示该种书还没被人借过 { m=(LinkList *)malloc(sizeof(LNode));//分配 boo[mid].next=m;//该图书信息中的链表的第一个结点 strcpy(m-CardNum,CaNum); m-next=NULL;//后一个结点为空 } else //如果已经有人在借这书了 { m=boo[mid].next; while(m-next) //遍历到最后一个结点 m=m-next; n=(LinkList *)malloc(sizeof(LNode));//分配空间,增加1个结点 m-next=n; strcpy(n-CardNum,CaNum);//记录证号 n-next=NULL; } int i=0; for(i=0;iRetotal;i++)// { if(!strcmp(Lin[i].CNum,CaNum))//如果已经有该图书证的信息 { p=Lin[i].next; while(p-next)p=p-next;//遍历到最后一个结点 q=(Bor *)malloc(sizeof(Boro));//分配空间 p-next=q; strcpy(q-BNum,BorrowNum); //记录书号 printf("输入归还日期:"); scanf("%s",q-RetDate); q-next=NULL; printf("借阅成功.\n"); break; //找到证了就跳出循环 } } if(i==Retotal)//如果没有这张证的信息 { strcpy(Lin[i].CNum,CaNum); //记录证号 p=(Bor *)malloc(sizeof(Boro)); //分配空间 Lin[i].next=p; strcpy(p-BNum,BorrowNum); printf("输入归还日期:"); scanf(" %s",p-RetDate); p-next=NULL; Retotal++; //借阅证号信息总数加1 printf("借阅成功.\n"); } } else printf("借阅失败.该书现在库存为0.\n"); } } void Return(ook boo,lend Lin,char ReturnNum[],char BorrowerNum[]) {//4、 归还:注销对借阅者的登记,改变该书的现存量。 Bor *p,*q; LinkList *m,*n; int flag=0;//设置一个参数 if(!BinarySearch(boo,ReturnNum)||!total) //没书 printf("书库中无此书.\n"); if(BinarySearch(boo,ReturnNum)) //有书 { m=boo[mid].next; if(!strcmp(m-CardNum,BorrowerNum)) //如果是第一个借的人还的 { boo[mid].NowNum++; //现库存加1 boo[mid].next=m-next; //删除结点 free(m); //释放该结点的空间空间 } else { while(m-next) //查找归还者的借阅者结点 { if(!strcmp(m-next-CardNum,BorrowerNum)) //如果找到 { n=m-next; //n为归还者的借阅结点 m-next=n-next; //m指向归还者的借阅结点的下一结点 free(n); //释放空间 boo[mid].NowNum++; //现库存加1 break; } m=m-next; } } } //在借阅者表里查找借阅者信息 for(int i=0;iRetotal;i++) { if(!strcmp(Lin[i].CNum,BorrowerNum)) //如果找到借阅者 { p=Lin[i].next; if(!strcmp(p-BNum,ReturnNum)) //如果是归还的是借的第一本书 { Lin[i].next=p-next; //指向下一借书结点 free(p); //释放结点空间 printf("成功归还该书.\n"); flag=1; break; } else //找不到 { while(p-next) //找到归还书的借书结点 { if(!strcmp(p-next-BNum,ReturnNum)) //如果找到 { q=p-next; //q为归还书的借书结点 p-next=q-next; //p指向下一借书结点 free(q); //释放空间 printf("成功归还该书.\n"); flag=1; break; } p=p-next; } } } } for(int k=0;kRetotal;k++) if(!Lin[k].next) { int j; for(j=k;jRetotal;j++) Lin[j]=Lin[j+1]; //其后都往前移一位,覆盖掉当前信息 strcpy(Lin[j].CNum," "); //删除图书证号 Retotal--; //图书证数减1 } //删除当前状态下没借书的图书证的信息,节省空间 if(flag==0) printf("无该证信息.\n"); } //5、 查找:实现按三种查询条件之一查找:按书号查找、 //按书名查找、按作者查找。注:可不实现组合查找,即几个条件组合查找。 void SearchByNum(ook boo,char SeaNum[]) {//BY NUM 根据书号查找 LinkList *p; p=boo[mid].next; if(BinarySearch(boo,SeaNum)==false)printf("对不起,未找到您想查找的书。\n");//二分查找 没找到 else//找到了的话 { { printf("┏━━━━━━━┳━━━━━━━┳━━━━━━━━┳━━━━━━━━┳━━━━━┳━━━━━┓\n"); printf("┃ 书号 ┃ 书名 ┃ 作者 ┃ 出版社 ┃ 现库存 ┃ 总库存 ┃\n"); printf("┣━━━━━━━╋━━━━━━━╋━━━━━━━━╋━━━━━━━━╋━━━━━╋━━━━━┫\n"); printf("┃%14s┃%14s┃%16s┃%16s┃%10d┃%10d┃\n",boo[mid].num,boo[mid].name,boo[mid].auth,boo[mid].pub,boo[mid].NowNum,boo[mid].TotNum); printf("┗━━━━━━━┻━━━━━━━┻━━━━━━━━┻━━━━━━━━┻━━━━━┻━━━━━┛\n"); if(boo[mid].next!=NULL) { printf("┏━━━━━━━┓\n"); printf("┃ 已借该书的 ┃\n"); printf("┃ 图书证号 ┃\n"); while(p) { printf("┣━━━━━━━┫\n"); printf("┃%14s┃\n",p-CardNum); p=p-next; } printf("┗━━━━━━━┛\n"); } } while(p) { printf(" %s ",p-CardNum);//在按书号查找的函数里也显示借了这本书的借阅者的证号 p=p-next; } printf(" \n"); }//显示查找的书籍的信息 } void SearchByName(ook boo) {//BY NAME 根据书名查找 char SeaName[20]; printf("输入想查找的书的书名:\n"); scanf(" %s",SeaName); printf("找到符合该书名的书的详细信息如下:\n"); for(int i=0;itotal;i++) { if(strcmp(SeaName,boo[i].name)==0)//如果书名一样 { printf("书号:%s\n书名:%s\n作者:%s\n出版社:%s\n总库存量:%d\n现库存量:%d\n\n",boo[i].num,boo[i].name,boo[i].auth,boo[i].pub,boo[i].TotNum,boo[i].NowNum); }//显示符合信息的所有书籍的信息 } } void SearchByAuth(ook boo) {// BY AUTH 根据作者查找 char SeaAuth[20]; printf("输入想查找的书的作者:\n"); scanf(" %s",SeaAuth); printf("找到符合该作者的书的详细信息如下:\n"); for(int i=0;itotal;i++) { if(strcmp(SeaAuth,boo[i].auth)==0)//如果作者一样 { printf("书号:%s\n书名:%s\n作者:%s\n出版社:%s\n总库存量:%d\n现库存量:%d\n\n",boo[i].num,boo[i].name,boo[i].auth,boo[i].pub,boo[i].TotNum,boo[i].NowNum); }//显示符合信息的所有书籍的信息 } } //6、 查看:可查看某图书证号的借阅者借阅的全部图书,可查看全部超期未还的图书。 void ViewCard(ook boo,lend Lin) {//查看某图书证号的借阅者借阅的全部图书 char Num[20]; printf("请输入您所想要查看的图书证号:\n"); scanf(" %s",Num); Bor *p; int qqq=0; for(int i=0;iRetotal;i++) { if(strcmp(Lin[i].CNum,Num)==0) //找到该证 { printf("这个证借的书有:\n"); p=Lin[i].next; while(p) { printf(" %s ",p-BNum); //书号 p=p-next; } printf("\n"); qqq=1; break; } } if(qqq==0) printf("该证不存在.\n"); } void ViewBook(ook boo,lend Lin) {//查看全部超期未还的图书 char date[8]; Bor *p; printf("请输入日期(请按格式20060605输入):\n"); scanf(" %s",date); printf("所有超期未还的书有:\n"); for(int i=0;iRetotal;i++) { p=Lin[i].next; while(p)//当p不空时 { if(strcmp(p-RetDate,date)0) //超过日期 { printf("书号为 %s 证号为 %s 应归还日期为 %s \n",p-BNum,Lin[i].CNum,p-RetDate); }//显示所有超期未还的书的信息 p=p-next; } } } void Menu() //菜单 { printf("┏—————————————————M E N U————————————————┓\n"); printf("│ │\n"); printf("│ 1. 采编入库:新购入一种书,如果该书在图书账目中已经存在, │\n"); printf("│ 则将其库存量增加(包括总库存量和现库存量)。 │\n"); printf("│ 如果该书不存在,则在图书账目中增加一种书, │\n"); printf("│ 总库存量和现库存量均为输入的数字。 │\n"); printf("│ 2. 清空库存:某一种书已无保留价值,将它从图书账目中注销。 │\n"); printf("│ 3. 借阅:如果一种书的现库存量大于零,则借出一本书,将现库存量减1, │\n"); printf("│ 并登记借阅者的图书证号和归还期限。 │\n"); printf("│ 4. 归还:注销对借阅者的登记,改变该书的现存量。 │\n"); printf("│ 5. 按书号查找。 │\n"); printf("│ 6. 按书名查找。 │\n"); printf("│ 7. 按作者查找。 │\n"); printf("│ 8. 查看某图书证号的借阅者借阅的全部图书。 │\n"); printf("│ 9. 查看全部超期未还的图书。 │\n"); printf("│ 0. 退出图书管理系统。 │\n"); printf("│ │\n"); printf("┗—————————————请 选 择 你 需 要 的 操 作————————————┛\n"); } void main() { ook Bo; lend Lin; char BNum[20]; char CNum[20]; printf("-----------------------欢 迎 进 入 图 书 管 理 系 统!---------------------------\n\n"); int choice=10; int SearchCho=10,ViewCho=10; while(choice!=0) { Menu();//显示菜单 scanf(" %d",choice); switch(choice) { case 1://采编入库 printf("请输入入库的书的书号:"); scanf(" %s",BNum); Buy(Bo,BNum); break; case 2://清空库存 printf("请输入想要清除的书的书号:"); scanf(" %s",BNum); Delete(Bo,BNum); break; case 3://借阅 printf("请输入想要借阅的书的书号:\n"); scanf(" %s",BNum); printf("请输入图书证号:"); scanf(" %s",CNum); Borrow(Bo,Lin,BNum,CNum); break; case 4://归还 printf("请输入想要归还的书的书号:\n"); scanf(" %s",BNum); printf("请输入图书证号:"); scanf(" %s",CNum); Return(Bo,Lin,BNum,CNum); break; case 5://查找//根据书号查找 printf("请输入书号:");//输入书号查找 scanf(" %s",BNum); SearchByNum(Bo,BNum); break; case 6://根据书名查找 SearchByName(Bo); break; case 7://根据作者查找 SearchByAuth(Bo); break; case 8://查看某图书证所借的所有书 ViewCard(Bo,Lin); break; case 9: //查看全部超期未还的书 ViewBook(Bo,Lin); break; case 0://退出系统 exit(0);break; default:printf("输入错误!\n");exit(0);break; } } }

求数据结构—图书管理系统源程序,要求实现以下功能。

#include iostream

#include iomanip

#include string

#include fstream//输入/输出文件流类

using namespace std;

const int Maxr=100;//最多的读者

const int Maxb=100;//最多的图书

const int Maxbor=5;//每位读者最多借五本书

//读者类,实现对读者的信息的描述

class Reader

{

private:

int tag; //删除标记 1:已删 0:未删

int no; //读者编号

char name[10]; //读者姓名

int borbook[Maxbor];//所借图书

public:

Reader() {}

char *getname() {return name;} //获取姓名

int gettag() {return tag;} //获取删除标记

int getno() {return no;} //获取读者编号

void setname(char na[]) //设置姓名

{

strcpy(name,na);

}

void delbook(){ tag=1; }//设置删除标记 1:已删 0:未删

void addreader(int n,char *na)//增加读者

{

tag=0;

no=n;

strcpy(name,na);

for(int i=0;iMaxbor;i++)

borbook[i]=0;

}

void borrowbook(int bookid)//借书操作

{

for(int i=0;iMaxbor;i++)

{

if (borbook[i]==0)

{

borbook[i]=bookid;

return;

}

}

}

int retbook(int bookid)//还书操作

{

for(int i=0;iMaxbor;i++)

{

if(borbook[i]==bookid)

{

borbook[i]=0;

return 1;

}

}

return 0;

}

void disp()//读出读者信息

{

cout setw(5) no setw(10) name"借书编号:[";

for(int i=0;iMaxbor;i++)

if(borbook[i]!=0)

cout borbook[i] "|";

cout "]"endl;

}

};

//读者类库,实现建立读者的个人资料

class RDatabase

{

private:

int top; //读者记录指针

Reader read[Maxr];//读者记录

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++;

read[top]=s;

}

file.close(); //关闭 reader.txt

}

void clear()//删除所有读者信息

{

top=-1;

}

int addreader(int n,char *na)//添加读者时先查找是否存在

{

Reader *p=query(n);

if (p==NULL)

{

top++;

read[top].addreader(n,na);

return 1;

}

return 0;

}

Reader *query(int readerid)//按编号查找

{

for (int i=0;i=top;i++)

if (read[i].getno()==readerid

read[i].gettag()==0)

{

return read[i];

}

return NULL;

}

void disp() //输出所有读者信息

{

for (int i=0;i=top;i++)

read[i].disp();

}

void readerdata();//读者库维护

~RDatabase() //析构函数,将read[]写到reader.txt文件中

{

fstream file("reader.txt",ios::out);

for (int i=0;i=top;i++)

if (read[i].gettag()==0)

file.write((char *)read[i],sizeof(read[i]));

file.close();

}

};

void RDatabase::readerdata()

{

char choice;

char rname[20];

int readerid;

Reader *r;

while (choice!='0')

{

cout "\n\n\t\t\t读 者 维 护\n\n\n\t\t 1 新 增\n\n\t\t 2 更 改\n\n\t\t 3 删 除\n\n\t\t 4 查 找\n\n\t\t 5 显 示\n\n\t\t 6 全 删\n\n\t\t 0 退 出"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;

}

}

}

//图书类,实现对图书的描述,图书的编号,书名,借出,还入等

class Book

{

private:

int tag;//删除标记 1:已删 0:未删

int no;//图书编号

char name[20];//书名

int onshelf;//是否再架 1:再架 2:已借

public:

Book(){}

char *getname() { return name; }//获取姓名

int getno(){ return no; }//获取图书编号

int gettag(){ return tag; }//获取删除标记

void setname(char na[])//设置书名

{

strcpy(name,na);

}

void delbook(){ tag=1;}//删除图书

void addbook(int n,char *na)//增加图书

{

tag=0;

no=n;

strcpy(name,na);

onshelf=1;

}

int borrowbook()//借书操作

{

if (onshelf==1)

{

onshelf=0;

return 1;

}

return 0;

}

void retbook()//还书操作

{

onshelf=1;

}

void disp()//输出图书

{

cout setw(6) no setw(18) name setw(10)

(onshelf==1? "在架":"已借") endl;

}

};

//图书库类,实现对图书的维护,查找,删除等

class BDatabase

{

private:

int top; //图书记录指针

Book book[Maxb]; //图书记录

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++;

book[top]=b;

}

file.close();

}

void clear()//全删

{

top=-1;

}

int addbook(int n,char *na)//增加图书

{

Book *p=query(n);

if (NULL==p)

{

top++;

book[top].addbook(n,na);

return 1;

}

return 0;

}

Book *query(int bookid)//查找图书

{

for (int i=0;i=top;i++)

if (book[i].getno()==bookid book[i].gettag()==0)

{

return book[i];

}

return NULL;

}

void bookdata();//图书库维护

void disp()

{

for (int i=0;i=top;i++)

if (book[i].gettag()==0)

book[i].disp();

}

~BDatabase()//析构函数,将book[]写到book.txt文件中

{

fstream file("book.txt",ios::out);

for (int i=0;i=top;i++)

if (book[i].gettag()==0)

file.write((char *)book[i],sizeof(book[i]));

file.close();

}

};

void BDatabase::bookdata()

{

char choice;

char bname[40];

int bookid;

Book *b;

while (choice!='0')

{

cout "\n\n\n\t\t\t图 书 维 护 "endlendl;

cout"\t\t1 新 增\n \t\t2 更 改\n\t\t3 删 除\n\t\t4 查 找\n\t\t5 显 示\n\t\t6 全 删\n\t\t0 退 出"endl;

cin choice;

switch (choice)

{

case '1':

cout "输入图书编号:"endl;

cin bookid;

cout "输入图书书名:"endl;

cin bname;

addbook(bookid,bname);

break;

case '2':

cout "输入图书编号:"endl;

cin bookid;

b=query(bookid);

if (b==NULL)

{

cout " 该图书不存在 "endl;

break;

}

cout "输入新的书名:"endl;

cin bname;

b-setname(bname);

break;

case '3':

cout " 读入图书编号:"endl;

cin bookid;

b=query(bookid);

if (b==NULL)

{

cout " 该图书不存在" endl;

break;

}

b-delbook();

break;

case '4':

cout " 读入图书编号:"endl;

cin bookid;

b=query(bookid);

if (b==NULL)

{

cout " 该图书不存在" endl;

break;

}

b-disp();

break;

case '5':

disp();

break;

case '6':

clear();

break;

default:cout"输入错误,请从新输入:";

}

}

}

//main() 函数的实现,程序的主界面的引导

void main()

{

char choice;

int bookid,readerid;

RDatabase ReaderDB;

Reader *r;

BDatabase BookDB;

Book *b;

while(choice!='0')

{

cout endlendl"\t\t\t 图 书 管 理 系 统\n\n\n";

cout "\t\t\t1 借 书\n\n\t\t\t2 还 书 \n\n\t\t\t3 图 书 维 护\n\n\t\t\t4 读 者 维 护\n\n\t\t\t0 离 开"endl;

cin choice;

switch (choice)

{

case '1':

cout " 借书 读者编号:";

cin readerid;

cout " 图书编号: ";

cin bookid;

r=ReaderDB.query(readerid);//按编号查找

if (NULL==r)

{

cout " 不存在该读者,不能借书" endl;

break;

}

b=BookDB.query(bookid);

if (b==NULL)

{

cout " 不存在该图书,不能借书" endl;

break;

}

if (b-borrowbook()==0)

{

cout " 该图书已借出,不能借书" endl;

break;

}

r-borrowbook(b-getno());

break;

case '2':

cout"还书\n 读者编号:";

cin readerid;

cout " 图书编号:";

cin bookid;

r=ReaderDB.query(readerid);

if (r==NULL)

{

cout " 不存在该读者,不能还书" endl;

break;

}

b=BookDB.query(bookid);

if (b==NULL)

{

cout " 不存在该图书,不能还书" endl;

break;

}

b-retbook();

r-retbook(b-getno());

break;

case '3':

BookDB.bookdata();

break;

case '4':

ReaderDB.readerdata();

break;

default:cout"输入错误,请从新输入:";

}

}

}

用数据结构编一个图书管理系统

#includestdio.h

#includestring.h

#includeconio.h

#includestdlib.h

#define N sizeof(struct book)

#define PT "%-5d %10s %6s %6s %8s %3d \n",p-num,p-name,p-where,p-author,p-pub,p-count

struct book /*图书信息*/

{

int num; /*书号*/

char name[10]; /*书名*/

char where[10]; /*所在书库*/

char author[15]; /*作者*/

char pub[20]; /*出版社*/

int count; /*数量*/

struct book *next;

};

/*输出模块*/

void print(struct book *p0)

{

struct book *p;

p=p0-next;

printf("\n\n\t\t^^^^^^^^^^^^^^图书信息表^^^^^^^^^^^^^^");

printf("\n\n图书编号---图书名称---所在书库----作者----出版社---数量\n");

while(p!=NULL)

{

printf(PT);

p=p-next;

}

getch();

}

/*输入模块*/

struct book *creat()

{

struct book *head,*p1,*p2;

int i=0;

head=p2=(struct book *)malloc(N);

head-next=NULL;

printf("\n\n\t\t录入图书信息");

printf("\n\t---------------------------------------");

while(1)

{ p1=(struct book *)malloc(N);

printf("\n 请输入图书编号(书号为0结束): ");

scanf("%d",p1-num);

if(p1-num!=0)

{

printf("\n\n书名 所在书库 作者 出版社 图书数量\n");

scanf("%s%s%s%s%d",p1-name,p1-where,p1-author,p1-pub,p1-count);

p2-next=p1;

p2=p1;

i++;

}

else

break;

}

p2-next=NULL;

free(p1);

printf("\n\t\t----------------------------------------");

printf("\n\t\t %d 种书录入完毕",i);

getch();

return head;

}

/*查找模块*/

void find(struct book *p0)

{

char name[10];

int flag=1;

struct book *p;

p=p0-next;

printf("请输入要查找的书名:\n");

scanf("%s",name);

for(p=p0;p;p=p-next)

if(strcmp(p-name,name)==0)

{

printf("\n\n图书编号---图书名称---所在书库----作者----出版社---数量\n");

printf(PT);

flag=0;

break;

}

if(flag) printf("\n 暂无此图书信息\n");

getch();

}

/*删除模块*/

void del(struct book *p0)

{

char name[10];

int flag=1;

struct book *p;

p=p0;

printf("请输入要删除的书名:\n");

scanf("%s",name);

while(p!=NULL)

{

if(strcmp(p-name,name)==0)

{

p0-next=p-next; /*后续节点连接到前驱节点之后*/

free(p);

printf("\t该书资料已删除.");

flag=0;

break;

}

p0=p;

p=p-next;

}

if(flag) printf("\n\t无此图书信息。");

getch();

}

/*增加模块*/

void insert(struct book *p0)

{

struct book *p;

p=(struct book *)malloc(N);

while(1)

{

printf("\n 请输入要增加的图书编号(书号为0 退出): ");

scanf("%d",p-num);

if(p-num!=0)

{

if(p0-next!=NULLp0-next-num==p-num) /*找到重号*/

{

p=p-next;

free(p);

printf("\t该书已存在");

}

else

{printf("\n\n书名 所在书库 作者 出版社 图书数量\n");

scanf("%s%s%s%s%d",p-name,p-where,p-author,p-pub,p-count);

p-next=p0-next;

p0-next=p;

printf("\t已成功插入.");

}

}

else

break;

}

getch();

}

/*修改模块*/

void modify(struct book *p0)

{

char name[10];

int flag=1;

int choice;

struct book *p;

p=p0-next;

printf("请输入要修改的书名:\n");

scanf("%s",name);

while(p!=NULLflag==1)

{

if(strcmp(p-name,name)==0)

{

printf("\n\t请选择要修改的项:");

printf("\n\t 1.修改图书编号\n");

printf("\n\t 2.修改图书所在书库\n");

printf("\n\t 3.修改图书作者\n");

printf("\n\t 4.修改图书出版社\n");

printf("\n\t 5.修改图书库存量\n");

scanf("%d",choice);

switch(choice)

{

case 1: { printf("\n 请输入新的图书编号:");

scanf("%d",p-num); break;

}

case 2: { printf("\n 请输入新的图书书库:");

scanf("%s",p-where); break;

}

case 3: { printf("\n 请输入新的图书作者:");

scanf("%s",p-author); break;

}

case 4: {printf("\n 请输入新的图书出版社:");

scanf("%s",p-pub); break;

}

case 5: {printf("\n 请输入新的图书库存量:");

scanf("%d",p-count); break;

}

}

printf("\n\t该项已成功修改。\n\t 新的图书信息:");

printf("\n\n图书编号---图书名称---所在书库----作者----出版社---数量\n");

printf(PT);

flag=0;

}

p0=p;

p=p0-next;

}

if(flag) printf("\n\t暂无此图书信息。");

getch();

}

/*读文件*/

struct book *read_file()

{

int i=0;

struct book *p,*p1,*head=NULL;

FILE *fp;

if((fp=fopen("library.txt","rb"))==NULL)

{printf("\n\n\n\n\n \t********库文件不存在,请创建!**********");

getch();

return NULL;

}

head=(struct book *)malloc(N);

p1=head;

head-next=NULL;

printf("\n 已有图书信息:");

printf("\n\n图书编号---图书名称---所在书库----作者----出版社---数量\n");

while(!feof(fp))

{

p=(struct book *)malloc(N); /*开辟空间以存放的取得信息*/

while(fscanf(fp,"%d%s%s%s%s%d",p-num,p-name,p-where,p-author,p-pub,p-count)!=EOF)

{

printf(PT);

i++;

}

p1-next=p;

p1=p;

}

p1-next=NULL;

fclose(fp);

printf("\n 共种%d 图书信息",i);

printf("\n\n\n 文件中的信息以正确读出。按任意键进入主菜单。");

getch();

return (head);

}

/*保存文件*/

void save(struct book *head)

{

FILE *fp;

struct book *p;

fp=fopen("library.txt","wb"); /*以只写方式打开二进制文件*/

if(fp==NULL) /*打开文件失败*/

{

printf("\n=====打开文件失败!\n");

getch();

return ;

}

else

for(p=head-next;p!=NULL;p=p-next)

fprintf(fp,"%d %s %s %s %s %d\n",p-num,p-name,p-where,p-author,p-pub,p-count);

fclose(fp);

printf("\n\t保存文件成功!\n");

}

void main()

{

struct book *head=NULL;

int choice=1;

head=read_file();

if(head==NULL)

{

printf("\n\t\t**********");

getch();

head=creat();

}

do

{

system("cls");

printf("\t\t----------Welcome---------\n");

printf("\n\n\t欢迎您,图书管理员.\n");

printf("\n\n\n\n\n");

printf("\n\t 请选择:");

printf("\n\t 1.查询图书信息\n");

printf("\n\t 2.修改图书信息\n");

printf("\n\t 3.增加图书信息\n");

printf("\n\t 4.删除图书信息\n");

printf("\n\t 5.显示所有图书信息\n");

printf("\n\t 0.退出系统\n");

scanf("%d",choice);

switch(choice)

{

case 1: find(head); break;

case 2: modify(head); break;

case 3: insert(head); break;

case 4: del(head); break;

case 5: print(head); break;

case 0: system("cls");

printf("\n\n\n\n\n\t^^^^^^^^^^谢谢使用,再见^^^^^^^^^^!\n\n");

break;

}

}while(choice!=0);

save(head);

}

数据结构图书管理系统源代码的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于数据结构图书馆管理信息系统代码、数据结构图书管理系统源代码的信息别忘了在本站进行查找喔。

版权说明:如非注明,本站文章均为 AH站长 原创,转载请注明出处和附带本文链接;

本文地址:http://ahzz.com.cn/post/25465.html


取消回复欢迎 发表评论:

分享到

温馨提示

下载成功了么?或者链接失效了?

联系我们反馈

立即下载