数据结构图书管理系统课程设计报告Word下载.docx

上传人:b****3 文档编号:14420654 上传时间:2022-10-22 格式:DOCX 页数:20 大小:248.26KB
下载 相关 举报
数据结构图书管理系统课程设计报告Word下载.docx_第1页
第1页 / 共20页
数据结构图书管理系统课程设计报告Word下载.docx_第2页
第2页 / 共20页
数据结构图书管理系统课程设计报告Word下载.docx_第3页
第3页 / 共20页
数据结构图书管理系统课程设计报告Word下载.docx_第4页
第4页 / 共20页
数据结构图书管理系统课程设计报告Word下载.docx_第5页
第5页 / 共20页
点击查看更多>>
下载资源
资源描述

数据结构图书管理系统课程设计报告Word下载.docx

《数据结构图书管理系统课程设计报告Word下载.docx》由会员分享,可在线阅读,更多相关《数据结构图书管理系统课程设计报告Word下载.docx(20页珍藏版)》请在冰豆网上搜索。

数据结构图书管理系统课程设计报告Word下载.docx

2)新书入库

新书采编入库,输入编号后如果有次数只需输入数量,没有则继续输入书名、作者、数量。

3)添加读者信息

读者信息初始化,输入读书证号和姓名,只有输入书证号和姓名才能进行借书还书

4)退出和文件保存

退出读书管理系统并保存读者和图书信息。

图书管理系统

图书管理模块

读者管理模块

借阅操作模块

查询操作模块

初始化图书信息

采编入库

输入读者信息

借书系统

还书系统

读者信息查询

图书信息查询

  

 

四、概要设计

图书信息和读者信息都采用结构体类型保存。

图书信息里面包括:

图书编号、图书名称、作者、现有量、库存量、指向下一节点的指针。

读者信息里面包括:

读者编号、读者姓名、借书数量、可借图书数量、指向下一节点的指针。

所有图书和读者都分别以链表的形式存储,并以编号为唯一主键。

采用链表形式便于数据的添加与删改。

主要的操作为:

系统初始化,图书入库,读者信息登记,图书信息和读者信息文件的保存。

五、详细设计

数据结构的定义:

图书信息:

typedefstructbook

{

charbook_num[10];

charbook_name[20];

charbook_writer[10];

intbook_xy;

intbook_kc;

structbook*next;

}BK;

读者信息:

typedefstructreader

charreader_num[10];

charreader_name[10];

intright;

BOborrow[Max];

structreader*next;

}RD;

算法描述:

进入系统后首先进行图书初始化,输入图书的信息。

开始

输入图书编号、名称、作者和图书数量

进入系统

1)初始化

初始化之后,进入系统,显示功能列表,可选择任意系统,但在借书之前先要输入读者信息。

2)采编入库

3)输入读者信息

5)退出和文件保存

退出系统

保存文件

判断是否保存成功

错误!

请重新登陆系统

六、程序源代码

#include<

stdio.h>

#include<

string.h>

stdlib.h>

conio.h>

#defineMax4

//现有

//库存

typedefstructborrow

charborrow_book_num[10];

charlimit_date[10];

}BO;

BK*h_book;

RD*h_reader;

voidLogin();

intMenu();

voidInit();

voidInit_book();

voidMenu_select();

voidInsert_New_Book();

voidFind_Book();

voidadd_reader();

voidSave();

voidSave_Book();

voidSave_Reader();

voidLoad();

voidLoad_Reader();

voidLoad_Book();

voidLogin()

system("

cls"

);

printf("

\n\n\n\t\t***************************************\n"

\n\n\n\t\t\t欢迎使用图书管理系统\n"

\n\n\n\t\t按任意键进入系统"

getch();

system("

}

intMenu()/*主菜单*/

{intdm;

\n\t\t图书管理系统主菜单\n"

=================================================\n"

*\t0----退出系统\n"

*\t1----采编入库\n"

*\t2----登记读者\n"

请选择相应的代码:

"

for(;

;

{scanf("

%d"

&

dm);

//dm输入的数字

if(dm<

0||dm>

6)

printf("

\n错误!

请重新输入:

elsebreak;

returndm;

voidMenu_select()/*主菜单选择函数*/

switch(Menu())/*功能选择*/

{case0:

Save();

\n\n\t文件保存成功!

\n"

\n\n\t欢迎下次使用本系统!

getch();

exit(0);

case1:

Insert_New_Book();

break;

case2:

add_reader();

default:

exit(0);

voidInit()/*初始化*/

BK*p0;

\n图书初始化开始,请输入图书信息\n包括编号.书名.数量\n"

p0=(BK*)malloc(sizeof(BK));

h_book=p0;

\n请输入图书信息:

图书编号:

/*输入图书编号(唯一)*/

scanf("

%s"

p0->

book_num);

图书名称:

/*输入图书名称*/

book_name);

图书作者:

/*输入图书作者*/

book_writer);

图书数量:

/*输入图书数量*/

p0->

book_kc);

p0->

book_xy=p0->

book_kc;

/*开始时图书现有量和库存量相等*/

next=NULL;

\n图书信息初始化完毕!

按任意键继续下一步操作\n"

voidInsert_New_Book()/*新书入库*/

BK*p,*p0,*p1;

p=p1=h_book;

\n新书入库模块\n"

\n请输入新书信息\n包括书号.书名.数量\n"

p0=(BK*)malloc(sizeof(BK));

while(strcmp(p0->

book_num,p1->

book_num)!

=0&

&

p1->

next!

=NULL)

p1=p1->

next;

if(strcmp(p0->

book_num)==0)/*此处分两种情况,若图书编号存在,则直接进库,只须

输入书的数量*/

{

\n此编号图书已存在!

!

直接入库!

p1->

book_kc+=p0->

book_xy+=p0->

}

else/*若不存在,则需要输入其他的信息,然后在进行插入操作*/

//库存数量

while(p->

next)

{p=p->

if(h_book==NULL)h_book=p0;

/*此处分两种情况,链表中没有数据,head直接指向p0处*/

elsep->

next=p0;

/*此处分两种情况,链表中有数据,链表中最后元素的next指向p0

处*/

\n新书入库完毕!

voidadd_reader()/*添加读者*/

{RD*p0,*p,*p1;

inti;

p=h_reader;

\n读者初始化开始,请输入读者信息.\n包括书证号.姓名..\n"

if(p==NULL)

p0=(RD*)malloc(sizeof(RD));

/*申请新结点存储空间*/

h_reader=p0;

读者书证号:

reader_num);

读者姓名:

reader_name);

right=0;

for(i

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 求职职场 > 笔试

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1