数据结构图书管理系统_第1页
数据结构图书管理系统_第2页
数据结构图书管理系统_第3页
数据结构图书管理系统_第4页
数据结构图书管理系统_第5页
已阅读5页,还剩10页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、数 据 结 构课 程 设 计 说 明 书   学生姓名:学 号:学 院:专 业:题 目:成绩指导教师     年 月 日1 设计目的(小标题黑体五号字)设计一个计算机管理系统完成图书管理基本业务(数据可以存储在一个数据文件中,数据结构、具体数据自定)。2. 设计内容和要求具体功能有:1)每种书的登记内容包括书号、书名、著作者、出版单位、现存量和库存量;2)对书号建立索引表(线性表)以提高查找效率;3)采编入库:新购一种书,确定书号后,登记到图书帐目表中,如果表中已有,则只将库存量增加;4)借阅:如果一种书的现存量大于0,则借

2、出一本,登记借阅者的书证号和归还期限,改变现存量;5)归还:注销对借阅者的登记,改变该书的现存量。3本设计所采用的数据结构所用数据结构:线性表、查找、排序链表:用一组地址任意的存储单元存放线性表中的数据元素。以元素(数据元素的映象) + 指针(指示后继元素存储位置)= 结点(表示数据元素 或 数据元素的映象)以“结点的序列”表示线性表称作线性链表(单链表)单链表是一种链式存取的结构,为找第 i 个数据元素必须先找到第 i-1 个数据元素。因此,查找第 i 个数据元素的基本操作为:移动指针,比较 j 和 i。(1)malloc(size)在内存的动态存储区申请一个长度为size字节的连续空间。(

3、2)calloc(n,size)在内存的动态存储区申请n个长度为size字节的连续空间,函数返回值为分配空间的首地址。若此函数未被成功执行,函数返回值为0。(3)free(p)释放由指针p所指向的存储单元,而存储单元的大小是最近一次调用malloc()或calloc()函数时所申请的存储空间。运用了单链表的插入、删除、排序、修改等一些操作!4 功能模块详细设计4.1 详细设计思想(1) 基本思想:(2) 图书信息录入、图书信息的查询、图书信息的排序、图书信息的修改、图书信息的删除、图书的借阅、图书的归还、退出图书管理系统。(3) 程序中的主要函数有:void main() /主函数int Cr

4、eateListR(LinkList *L) /尾插法建表void LocateElem(LinkList *L) /查询 int Sort(LinkList *L) /递增有序排序(直接插入排序法)void Display(LinkList *L) /输出排序结果ModifyList(LinkList *L) /修改int ListDelete(LinkList *L) /删除 void Borrow(LinkList *L) /借阅void Return(LinkList *L) /归还图书信息的录入添加图书信息的查询模块图书信息的排序模块图书信息的修改模块图书信息的删除模块图书的借阅模块

5、图书的归还模块退出图书管理系统图 书 管 理 系 统主 程 序 模 块4.2 核心代码#include <stdio.h>#include <string.h>#include<stdlib.h>#include<malloc.h>typedef struct int num;char name20;char author20;char press20;int count;char price10; ElemType;typedef struct LNode/定义单链表结点类型ElemType data;struct LNode *next; L

6、inkList;void InitList(LinkList *L) /初始化线性表L = (LinkList *) malloc(sizeof(LinkList); /创建头结点L->next = NULL;int CreateListR(LinkList *L) /尾插法建表int i, n;LinkList *s, *q, *p;p = L;while (p->next != NULL )p = p->next;printf("请输入需要录入的图书信息的个数:n=");scanf("%d", &n);for (i = 1;

7、 i < n + 1; i+) s = (LinkList *) malloc(sizeof(LinkList);printf("书号 书名 作者 出版社名称 存馆数量 定价n");scanf("%d%s%s%s%d%s", &s->data.num, s->, s->data.author,s->data.press, &s->data.count, s->data.price);q = L->next;if (q = NULL ) p->next = s;p =

8、s;p->next = NULL;printf("录入成功!n");continue;while (q != NULL ) if (strcmp(s->, q->) = 0) printf("此图书已存在!");printf("请重新输入:n");scanf("%d%s%s%s%d%s", &p->data.num, p->,p->data.author, p->data.press, &p->da

9、ta.count,p->data.price);q = q->next;p->next = s;p = s;p->next = NULL;printf("录入成功!n");return 0;void LocateElem(LinkList *L) /查询LinkList *p = L->next; /p指向第一个数据结点int c;int x = 0;char name110, author110, press110;printf(" 1 按书名查询:n");printf(" 2 按作者名查询:n");p

10、rintf(" 3 按出版社名称:n");printf(" 4 返回n");printf(" 请选择1-4进行操作:n");scanf("%d", &c);if (c > 4 | c < 1) printf("您的输入有误!n");scanf("%d", &c);switch (c) case 1:printf("请输入图书书名: n");scanf("%s", name1);while (p != NULL

11、 ) if (strcmp(name1, p->) != 0) /查找图书书名p = p->next;else printf("书号 书名 作者 出版社名称 存馆数量 定价n");printf("%dt%st%st%st%dt%s", p->data.num, p->,p->data.author, p->data.press, p->data.count,p->data.price);printf("n");p = p->next;x+;if

12、(p = NULL && x = 0)printf("对不起,不存在此图书!n");break;case 2:printf("请输入图书作者:n");scanf("%s", author1);while (p != NULL ) if (strcmp(author1, p->data.author) != 0) /查找图书作者p = p->next;else printf("书号 书名 作者 出版社名称 存馆数量 定价n");printf("%dt%st%st%st%dt%s&

13、quot;, p->data.num, p->,p->data.author, p->data.press, p->data.count,p->data.price);printf("n");p = p->next;x+;if (p = NULL && x = 0)printf("对不起,不存在此图书!n");break;case 3:printf("请输入图书的出版社名称: n");scanf("%s", press1);while (p

14、 != NULL ) if (strcmp(press1, p->data.press) != 0) /查找图书出版社名称p = p->next;else printf("书号 书名 作者 出版社名称 存馆数量 定价n");printf("%d %s %s %s %d %s",p->data.num, p->, p->data.author,p->data.press, p->data.count, p->data.price);printf("n");p = p-&g

15、t;next;x+;if (p = NULL && x = 0)printf("对不起!不存在此图书n");break;case 4:break;int Sort(LinkList *L) /递增有序排序(直接插入排序法)LinkList *p = L->next, *q, *r; /p指向第一个数据结点if (p != NULL ) /若原单链表中有一个或以上的数据结点r = p->next; /r保存*p结点直接后继结点的指针p->next = NULL; /构造只含一个数据结点的有序表p = r;while (p != NULL )

16、r = p->next; /r保存*p结点的直接后继结点的指针q = L;while (q->next != NULL && q->next->data.num < p->data.num)q = q->next; /在有序表中找插入*p的直接前驱结点*q的位置p->next = q->next; /将*p插入到*q之后q->next = p;p = r; /扫描原单链表余下的结点return 0;void Display(LinkList *L) /输出排序结果LinkList *p = L->next;whi

17、le (p != NULL ) printf("书号 书名 作者 出版社名称 存馆数量 定价n");printf("%d t %s t %st %st%dt %s", p->data.num,p->, p->data.author, p->data.press, p->data.count,p->data.price);printf("n");p = p->next;int ModifyList(LinkList *L) /修改LinkList *p = L;char nam

18、e110;printf("请输入要修改的图书的书名:n");scanf("%s", name1);while (p != NULL ) if (strcmp(name1, p->) = 0) /查找所要修改的书名printf("请输入修改后的信息!n");printf("书号 书名 作者 出版社名称 存馆数量 定价n");scanf("%d%s%s%s%d%s", &p->data.num, p->, p->data.autho

19、r,p->data.press, &p->data.count, p->data.price);printf("修改成功!n");return 0;p = p->next;printf("不存在此图书n");return 0;int ListDelete(LinkList *L) /删除LinkList *p = L->next, *q = L;char name110;if (p != NULL ) printf("请输入要删除的书名:");scanf("%s", name1

20、);while (p->next != NULL && strcmp(p->, name1) != 0) p = p->next;q = q->next;if (p->next != NULL ) /如果p此时不是最后一个节点,说明此时已经找到书q->next = p->next;printf("删除成功!n");return 0;if (p->next = NULL && strcmp(name1, p->) != 0) /如果p此时为最后一个结点并且

21、没有找到与之相符的书名printf("你输入的书名不存在,请核实后重新输入!n"); else q->next = NULL;printf("删除成功!n");return 0;void Borrow(LinkList *L) /借阅LinkList *p = L->next;char name110;printf("请输入要借阅的图书的书名:n");scanf("%s", name1);while (p->next != NULL && strcmp(name1, p->d

22、) != 0)p = p->next;if (p->next = NULL && strcmp(name1, p->) != 0)printf("此图书不存在!n");else if (p->data.count < 1)printf("此书已借完!n");else if (strcmp(name1, p->) = 0) printf("借书成功!n");p->data.count-;void Return(LinkList

23、*L) /归还LinkList *p = L->next;char name110;printf("输入归还书的书名: n");scanf("%s", name1);while (p->next != NULL && strcmp(name1, p->) != 0)p = p->next;if (p->next = NULL && strcmp(name1, p->) != 0)printf("错误!此图书不存在!n");else if (strcmp(name1, p->) = 0) printf("该书归还成功!n");p->data.count+;void menu() /菜单函数printf("- n");printf(" 欢迎光临图书管理系统! n");printf("- n");printf("1.图书信息录入添加功能:n");printf("2.图书信息查询功能:n

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论