数据结构课程设计报告家电库存管理系统

上传人:仙*** 文档编号:34334761 上传时间:2021-10-21 格式:DOC 页数:24 大小:310KB
收藏 版权申诉 举报 下载
数据结构课程设计报告家电库存管理系统_第1页
第1页 / 共24页
数据结构课程设计报告家电库存管理系统_第2页
第2页 / 共24页
数据结构课程设计报告家电库存管理系统_第3页
第3页 / 共24页
资源描述:

《数据结构课程设计报告家电库存管理系统》由会员分享,可在线阅读,更多相关《数据结构课程设计报告家电库存管理系统(24页珍藏版)》请在装配图网上搜索。

1、XXXXXXX学院XXXXXX 系数据结构课程设计报告书 项目名称:家电库存管理系统 班级学号:XXXXXXXXXX 学生姓名:XXXXX 指导老师:XXX 完成时间:2011年X月X日 成绩评定: 老师签字: 目 录第一章 软件设计需求分析.1第二章 系统分析与设计.1 2.1 设计分析.1 2.1.1 设计理念.1 2.1.2 设计框架.1 2.2 详细设计.2 2.2.1 主要流程图.2 2.2.2 数据存储结构2 2.2.3 主函数的设计2 2.2.4 录入函数的设计.3 2.2.5 查询函数的设计.4 2.2.6 删除函数的设计.6 2.2.7 更改函数的设计.7第三章 软件测试.8

2、 3.1 函数模块的设计.8 3.1.1 添加记录函数的测试.8 3.1.2 查询函数的测试8 3.1.3 删除函数的测试.103.2 文件模块的测试.10 3.2.1 文件读取的测试.10 3.2.2 文件写入的测试.11第四章 软件使用说明书.13第五章 软件设计总结.13第六章 参考文献.13第七章 附录.14第一章 软件需求分析说明家电已成为每家每户的必需品,家里的家电种类越来越多。商场出售的家电 种类也越来越多,商场家电部管理和销售需要有规格有条理的管理方式,灵活记 录每天的情况。针对上面的情况,开发一个系统软件成为必然。该系统需要能够 方便的对每天进货提货操作和每天的销售额及库存总

3、价值进行记录,能够给小型 家电部门提供诸多方便。因此,家电库存系统应运而生。第二章 系统分析与设计2.1设计分析2.1.1设计理念家电库存系统以最简单操作界面,最少的内存使用和最高的效率为原则,带 给用户带来清爽的体验。进入主菜单,选择相应的功能即可进入相应的操作,操作完毕有相应的提示语。操作完毕,返回主菜单。2.1.2设计框架 主菜单读取记录保存记录添加记录删除记录查询记录更改记录退出记录查询所有按名称查询退出查询 2.2详细设计2.2.1主要流程图 开始输入a根据a的值进行选择各个函数操作a=1读取记录a=2保存记录a=3添加记录a=4删除记录a=5查询记录a=6更改记录a=0退出系统结束

4、2.2.2数据存储结构为了能够提高内存的利用,程序使用单链表结构,方便频繁的插入、删除和 排序而不占用多余的内存。2.2.3主函数的设计 程序启动进入主函数,进入主菜单 界面和用户进行交互。 int main(void)/主函数 int y; linklist *l; char a; l=Initlist(l); while(1) printf( * 电 器 库 存 管 理 系 统 *nn); printf( *菜 单*nn); printf( * = * n); printf( * 1. 读 取 记 录 * n); printf( * 2. 保 存 记 录 * n); printf( * 3

5、. 添 加 记 录 * n); printf( * 4. 删 除 记 录 * n); printf( * 5. 查 询 记 录 * n); printf( * 6. 更 改 记 录 * n); printf( * 0. 退 出 系 统 * n); printf( * - * n); printf( 请输入你要进行的操作:); a = getch(); switch(a) case 1: l=read_file(l);break; case 2: write_file(l); break; case 3:l=add(l);BubbleSortList(l);break; case 4:delli

6、st(l);break; case 5:y=list(l);break; case 6:change(l);break; case 0:printf(n 感谢使用X-Sky电器库存管理系统n 按任意键退出.n);return 0;break; default:printf(输入错误,请重新输入:nn); 2.2.4录入函数的设计 选择添加记录,系统调用添加函数,在用户输入家电信息后添加到链表里, 在添加过程中自动寻找比自己价格高的家电,插入到它的前面。添加成功后,返回主菜单并提示用户保存。linklist *add(linklist *l) printf(进行添加的操作!n); int n,i

7、; linklist *p,*q; p=l; printf(要添加几条记录?n); scanf(%d,&n); while(p-next!=NULL) p=p-next; printf(请输入添加的记录n); printf(%10s %10s %10s %10s %10sn,编号,名称,品牌,价格,数量); for(i=1;idata.j=i; scanf(%10d %10s %10s %10d %10d,&p-data.j,q-data.name,q-data.pai,&q-data.price,&q-data.number); q-next=NULL; p-next=q; p=p-next

8、; printf(n添加记录成功n);printf(请保存!n); return l;2.2.5查询函数的设计 选择查询记录,系统调用查询函数,显示查询菜单。 查询菜单函数设计: int list(linklist *l)/查询菜单 char a; char b= ; while(1) printf(n * 查询 *n); printf( *菜单*n); printf( * = * n); printf( * 1. 查询所有家电记录 * n); printf( * 2. 按名称查询家电记录 * n); printf( * 0. 退出查询系统 * n); printf( * - * n); pr

9、intf( 请输入查询的方式:n); a = getch(); switch(a) case 0:return 0;break; case 1:list0(l);break; case 2:list1(l);break; default:printf(输入错误,请重新输入:n); 查询所有函数:void list0(linklist *l)/查询所有函数 int j=1; linklist *p; p=l-next; if(p=NULL) printf(没有记录,请输入记录n); else printf( n按照单价的升序进行排序后全部的记录n); printf(%10s %10s %10s

10、%10s %10sn,编号,名称,品牌,价格,数量); while(p!=NULL) printf(%10d %10s %10s %10d %10dn,p-data.j,p-data.name,p-data.pai,p-data.price,p-data.number); p=p-next; j+; 按名称查询函数:void list1(linklist *l)/按名称查询函数 linklist *p; p=l; int y; int j=1; char na20; printf(请输入查询家电的名称:); scanf(%s,na); printf(你要查询的记录为n); while(p!=N

11、ULL) y=StrCmp(na,p-data.name,20); if(y=1) j+; p=p-next; else printf(%10s %10s %10s %10s %10sn,编号,名称,品牌,价格,数量); printf(%10d %10s %10s %10d %10dn,p-data.j,p-data.name,p-data.pai,p-data.price,p-data.number); p=p-next; j+; 2.2.6删除函数的设计 删除函数的原理和查询函数原理一样,只是在找到对应的家电后删除结点,并提示用户保存! void dellist(linklist *l)/

12、删除记录函数 char na20; linklist *p,*q; q=l; p=l-next; int y; printf(n请输入你要删除家电的名称:); scanf(%s,na); while(p!=NULL) y=StrCmp(na,p-data.name,20); if(y=1) p=p-next; q=q-next; else printf(你删除的记录为n); printf(%10s %10s %10s %10s %10sn,编号,名称,品牌,价格,数量); printf(%10d %10s %10s %10d %10dn,p-data.j,p-data.name,p-data.

13、pai,p-data.price,p-data.number); q-next=p-next; p=p-next; printf(请保存!n); 2.2.7更改函数的设计 根据输入要更改的电器的名称,找到该电器的所有记录输出后提示输入新的数据,更改完后,返回主菜单并提示用户保存! void change(linklist *l)/更改记录函数 char na20; linklist *p,*q; q=l; p=l-next; int y; printf(n请输入你要修改家电的名称:); scanf(%s,na); while(p!=NULL) y=StrCmp(na,p-data.name,2

14、0); if(y=1) p=p-next; q=q-next; else printf(你要修改的记录为:n); printf(%10s %10s %10s %10s %10sn,编号,名称,品牌,价格,数量); printf(%10d %10s %10s %10d %10dn,p-data.j,p-data.name,p-data.pai,p-data.price,p-data.number); printf(请输入你修改记录的新信息:n); printf(%10s %10s %10s %10s %10sn,编号,名称,品牌,价格,数量); scanf(%10d %10s %10s %10d

15、 %10d,&q-data.j,p-data.name,p-data.pai,&p-data.price,&p-data.number); p=p-next; printf(修改成功! 请保存!n); 第三章 软件测试3.1函数模块的测试3.1.1添加记录函数的测试 添加记录3.1.2查询函数的测试 无记录时查询: 查询所有: 按名称查询: 退出查询系统: 输入0后,返回主菜单。 3.1.3删除函数的测试 3.2文件模块的测试3.2.1文件读取的测试 无记录时的读取: 有记录时的读取: 3.2.2文件写入的测试 文件写入前: 添加新的记录并文件写入后: 第四章 软件使用说明书用户首先需要启动程

16、序进入主菜单界面,下面分别是界面菜单的使用说明: 1. 读取记录:在此目录下,用户可以将库存文件记录读取并显示出来。 2. 保存记录:在此目录下,用户可以将记录保存到文件。 3. 添加记录:在此目录下,用户添加新的纪录。添加完后,系统会返回主菜单并提示用户保存,此时你要可以选择2保存,如果不选择保存则不会保存。4. 删除纪录:在此目录下,用户删除纪录。删除后,系统会返回主菜单并提示用户保存,此时你要可以选择2保存,如果不选择保存则不会删除。 5.查询记录:在此目录下,用户可以查询所有家电记录和按名称查询家电记录。 1.查询所有家电记录:显示所有的家电记录,如果没有记录则会提示用户输入记录。 2

17、.按名称查询家电记录:输入要查询家电的名称后,显示相应家电的信息。 0.退出查询系统:退出查询系统并返回主菜单。6. 更改记录:在此目录下,用户在原有的记录上更改记录。更改后,系统会返回主菜单并提示用户保存,此时你要可以选择2保存,如果不选择保存则不会更改。 0. 退出系统:提示按任意键退出系统。第五章 软件设计总结 一开始看到这个软件的设计要求,头都大了!不知道从何下手。后来在书上和网上查阅了很多资料,才找到了一点头绪。在老师和同学的帮助下,才勉强完成了这个程序的设计。 其实说来,这个程序并不难,主要是链表的应用,链表并不是很难,只是平时自己没有真正的好好去学这门课,没有把这个当成一回事去做

18、。甚至还埋怨老师给我们出这么难的题目。 通过这次的课程设计,我知道了自己是多么无知,连最基础的东西都不会,更不要说学更难更深得东西了,自己要学的东西真的是太多太多了! 最后我要感谢老师的指导和教诲!第六章 参考文献严蔚敏 吴伟民 数据结构(C语言版)清华大学出版社,2000文益民 周学毛 李健 数据结构与程序设计 人民邮电出版社 2008谭浩强 C程序设计(第三版) 清华大学出版设 2008林锐 韩永泉 高质量程序设计指南C+/C语言第3版 2007第七章 附录程序代码:#include#include#include#includetypedef struct/结构体定义 char name

19、20; char pai20; int price; int number; int j; struct node *next;elemtype;typedef struct node elemtype data; struct node *next;linklist;linklist *Initlist(linklist *p);linklist *add(linklist *l);void list0(linklist *l);int list(linklist *l);void list1(linklist *l);int StrCmp(char na,char name,int y);

20、void BubbleSortList(linklist *p) ;void dellist(linklist *l);void change(linklist *l);void write_file(linklist *l);linklist* read_file(linklist *l);int main(void)/主函数 int y; linklist *l; char a; l=Initlist(l); while(1) printf( * 电 器 库 存 管 理 系 统 *nn); printf( *菜 单*nn); printf( * = * n); printf( * 1. 读

21、 取 记 录 * n); printf( * 2. 保 存 记 录 * n); printf( * 3. 添 加 记 录 * n); printf( * 4. 删 除 记 录 * n); printf( * 5. 查 询 记 录 * n); printf( * 6. 更 改 记 录 * n); printf( * 0. 退 出 系 统 * n); printf( * - * n); printf( 请输入你要进行的操作:); a = getch(); switch(a) case 1: l=read_file(l);break; case 2: write_file(l); break; ca

22、se 3:l=add(l);BubbleSortList(l);break; case 4:dellist(l);break; case 5:y=list(l);break; case 6:change(l);break; case 0:printf(n 感谢使用X-Sky电器库存管理系统n 按任意键退出.n);return 0;break; default:printf(输入错误,请重新输入:nn); linklist *Initlist(linklist *p) p=(linklist*)malloc(sizeof(linklist); p-next=NULL; return p;link

23、list *add(linklist *l) printf(进行添加的操作!n); int n,i; linklist *p,*q; p=l; printf(要添加几条记录?n); scanf(%d,&n); while(p-next!=NULL) p=p-next; printf(请输入添加的记录n); printf(%10s %10s %10s %10s %10sn,编号,名称,品牌,价格,数量); for(i=1;idata.j=i; scanf(%10d %10s %10s %10d %10d,&p-data.j,q-data.name,q-data.pai,&q-data.price

24、,&q-data.number); q-next=NULL; p-next=q; p=p-next; printf(n添加记录成功n);printf(请保存!n); return l;int list(linklist *l)/查询菜单 char a; char b= ; while(1) printf(n * 查询 *n); printf( *菜单*n); printf( * = * n); printf( * 1. 查询所有家电记录 * n); printf( * 2. 按名称查询家电记录 * n); printf( * 0. 退出查询系统 * n); printf( * - * n);

25、printf( 请输入查询的方式:n); a = getch(); switch(a) case 0:return 0;break; case 1:list0(l);break; case 2:list1(l);break; default:printf(输入错误,请重新输入:n); void list0(linklist *l)/查询所有函数 int j=1; linklist *p; p=l-next; if(p=NULL) printf(没有记录,请输入记录n); else printf( n按照单价的升序进行排序后全部的记录n); printf(%10s %10s %10s %10s

26、%10sn,编号,名称,品牌,价格,数量); while(p!=NULL) printf(%10d %10s %10s %10d %10dn,p-data.j,p-data.name,p-data.pai,p-data.price,p-data.number); p=p-next; j+; void list1(linklist *l)/按名称查询函数 linklist *p; p=l; int y; int j=1; char na20; printf(请输入查询家电的名称:); scanf(%s,na); printf(你要查询的记录为n); while(p!=NULL) y=StrCmp

27、(na,p-data.name,20); if(y=1) j+; p=p-next; else printf(%10s %10s %10s %10s %10sn,编号,名称,品牌,价格,数量); printf(%10d %10s %10s %10d %10dn,p-data.j,p-data.name,p-data.pai,p-data.price,p-data.number); p=p-next; j+; int StrCmp(char na,char name,int y) int i =0; int n=0; while(nai) n+; i+; for(i=0;in;i+) if(na

28、i!=namei) break; if(inext; linklist *_node = p-next; elemtype temp; for (;_temp-next;_temp = _temp-next) for (_node = p-next;_node-next;_node = _node -next) if (_node-data.price _node-next-data.price) temp = _node-data; _node-data = _node-next-data; _node-next-data = temp; void dellist(linklist *l)/

29、删除记录函数 char na20; linklist *p,*q; q=l; p=l-next; int y; printf(n请输入你要删除家电的名称:); scanf(%s,na); while(p!=NULL) y=StrCmp(na,p-data.name,20); if(y=1) p=p-next; q=q-next; else printf(你删除的记录为n); printf(%10s %10s %10s %10s %10sn,编号,名称,品牌,价格,数量); printf(%10d %10s %10s %10d %10dn,p-data.j,p-data.name,p-data.

30、pai,p-data.price,p-data.number); q-next=p-next; p=p-next; printf(请保存!n); void change(linklist *l)/更改记录函数 char na20; linklist *p,*q; q=l; p=l-next; int y; printf(n请输入你要修改家电的名称:); scanf(%s,na); while(p!=NULL) y=StrCmp(na,p-data.name,20); if(y=1) p=p-next; q=q-next; else printf(你要修改的记录为:n); printf(%10s

31、 %10s %10s %10s %10sn,编号,名称,品牌,价格,数量); printf(%10d %10s %10s %10d %10dn,p-data.j,p-data.name,p-data.pai,p-data.price,p-data.number); printf(请输入你修改记录的新信息:n); printf(%10s %10s %10s %10s %10sn,编号,名称,品牌,价格,数量); scanf(%10d %10s %10s %10d %10d,&q-data.j,p-data.name,p-data.pai,&p-data.price,&p-data.number)

32、; p=p-next; printf(修改成功! 请保存!n); void write_file(linklist *l)/写入文件函数 char b; int j=1; int y; FILE *fp; printf( n%20sn,将数据写入文件n); b = n; y=remove(家电库存记录.txt); while(b=n|b=N) if(fp=fopen(家电库存记录.txt,a)=NULL) printf(保存失败!); linklist *p; p=l-next; if(p=NULL) printf(n没有记录,请输入记录n); else fseek(fp,0L,0); fpr

33、intf(fp,%10s %10s %10s %10s %10sn,编号,名称,品牌,价格,数量); while(p!=NULL) fprintf(fp,%10d %10s %10s %10d %10dn,p-data.j,p-data.name,p-data.pai,p-data.price,p-data.number); p=p-next; j+; printf(记录成功写入文件中!n); printf(n是否返回主菜单(y/n):n); b = getch(); fclose(fp); linklist* read_file(linklist *l)/读取函数 char b,g; int

34、 i; FILE *fp; linklist *p,*q,*t; p=Initlist(p); l=Initlist(l); t=l; printf( n%20sn,将数据从文件中读出n); b = n; while(b=n|b=N) if(fp=fopen(家电库存记录.txt,rb)=NULL) printf(n打开文件失败!,可能没有记录n); return 0; fseek(fp,54L,0); while(fscanf(fp,%10d %10s %10s %10d %10dn,&p-data.j,p-data.name,p-data.pai,&p-data.price,&p-data

35、.number)!=EOF) q=(linklist*)malloc(sizeof(linklist); q-next=NULL; q-data=p-data; t-next=q; t=t-next; fclose(fp); if(fp=fopen(家电库存记录.txt,rb)=NULL) printf(n打开文件失败!,可能没有记录n); return 0; while(!feof(fp) g=fgetc(fp); printf(%c,g); printf(读取成功!n); printf(n是否返回主菜单(y/n):n); b = getch(); fclose(fp); return l;

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

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!