数据结构课程设计报告电器库存管理系统.docx
- 文档编号:4666695
- 上传时间:2022-12-07
- 格式:DOCX
- 页数:30
- 大小:299.96KB
数据结构课程设计报告电器库存管理系统.docx
《数据结构课程设计报告电器库存管理系统.docx》由会员分享,可在线阅读,更多相关《数据结构课程设计报告电器库存管理系统.docx(30页珍藏版)》请在冰豆网上搜索。
数据结构课程设计报告电器库存管理系统
课程设计报告
课程设计名称:
数据结构课程设计
课程设计题目:
电器库存管理系统
院(系):
计算机信息工程学院
专业:
计算机科学与技术(网络方向)
班级:
15网络二班
学号:
2015220240241
姓名:
闫文辉
指导教师:
韩晶晶
完成日期:
2016年6月24日
目录
第1章系统分析与设计1
1.1.1设计理念1
1.1.2设计框架1
1.2.1主要流程图2
1.2.2数据存储结构2
1.2.3主函数的设计2
1.2.4录入函数的设计4
1.2.5查询函数的设计4
1.2.6删除函数的设计7
1.2.7更改函数的设计7
第2章软件测试9
2.1函数模块的测试9
2.1.1添加记录函数的测试9
2.1.2查询函数的测试9
2.1.3删除函数的测试11
2.2.1文件读取的测试11
2.2.2文件写入的测试12
第3章软件使用说明书14
第4章软件设计总结15
参考文献15
附录(程序清单)16
第1章系统分析与设计
1.1.1设计理念
家电库存系统以最简单操作界面,最少的内存使用和最高的效率为原则,带给用户带来清爽的体验。
进入主菜单,选择相应的功能即可进入相应的操作,操作完毕有相应的提示语。
操作完毕,返回主菜单。
1.1.2设计框架
1.1详细设计
1.2.1主要流程图
1.2.2数据存储结构
为了能够提高内存的利用,程序使用单链表结构,方便频繁的插入、删除和排序而不占用多余的内存。
1.2.3主函数的设计
程序启动进入主函数,进入主菜单界面和用户进行交互。
intmain(void)//主函数
{
inty;
linklist*l;
chara;
l=Initlist(l);
while
(1)
{
printf("***************电器库存管理系统*******************\n\n");
printf("*********************菜单***************************\n\n");
printf("*=======================================================*\n");
printf("*1.读取记录*\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;
case'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");return0;break;
default:
printf("输入错误,请重新输入:
\n\n");
}
}
}
1.2.4录入函数的设计
选择添加记录,系统调用添加函数,在用户输入家电信息后添加到链表里,在添加过程中自动寻找比自己价格高的家电,插入到它的前面。
添加成功后,返回主菜单并提示用户保存。
linklist*add(linklist*l)
{
printf("进行添加的操作!
\n");
intn,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%10s\n","编号","名称","品牌","价格","数量");
for(i=1;i<=n;i++)
{
printf("%8c",'');
q=(linklist*)malloc(sizeof(linklist));
q->data.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;
}
printf("\n添加记录成功\n");
printf("请保存!
\n");
returnl;
}
1.2.5查询函数的设计
选择查询记录,系统调用查询函数,显示查询菜单。
查询菜单函数设计:
intlist(linklist*l)//查询菜单
{
chara;
charb='';
while
(1)
{
printf("\n***************查询******************\n");
printf("*************************菜单********************************\n");
printf("*=========================================================*\n");
printf("*1.查询所有家电记录*\n");
printf("*2.按名称查询家电记录*\n");
printf("*0.退出查询系统*\n");
printf("*---------------------------------------------------------*\n");
printf("请输入查询的方式:
\n");
a=getch();
switch(a)
{
case'0':
return0;break;
case'1':
list0(l);break;
case'2':
list1(l);break;
default:
printf("输入错误,请重新输入:
\n");
}
}
}
查询所有函数:
voidlist0(linklist*l)//查询所有函数
{
intj=1;
linklist*p;
p=l->next;
if(p==NULL)
{
printf("没有记录,请输入记录\n");
}
else
{
printf("\n按照单价的升序进行排序后全部的记录\n");
printf("%10s%10s%10s%10s%10s\n","编号","名称","品牌","价格","数量");
while(p!
=NULL)
{
printf("%10d%10s%10s%10d%10d\n",p->data.j,p->data.name,p->data.pai,p->data.price,p->data.number);
p=p->next;
j++;
}
}
}
按名称查询函数:
voidlist1(linklist*l)//按名称查询函数
{
linklist*p;
p=l;
inty;
intj=1;
charna[20];
printf("请输入查询家电的名称:
");
scanf("%s",na);
printf("你要查询的记录为\n");
while(p!
=NULL)
{
y=StrCmp(na,p->data.name,20);
if(y==1)
{j++;
p=p->next;
}
else
{
printf("%10s%10s%10s%10s%10s\n","编号","名称","品牌","价格","数量");
printf("%10d%10s%10s%10d%10d\n",p->data.j,p->data.name,p->data.pai,p->data.price,p->data.number);
p=p->next;
j++;
}
}
}
1.2.6删除函数的设计
删除函数的原理和查询函数原理一样,只是在找到对应的家电后删除结点,并提示用户保存!
voiddellist(linklist*l)//删除记录函数
{
charna[20];
linklist*p,*q;
q=l;
p=l->next;
inty;
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%10s\n","编号","名称","品牌","价格","数量");
printf("%10d%10s%10s%10d%10d\n",p->data.j,p->data.name,p->data.pai,p->data.price,p->data.number);
q->next=p->next;
p=p->next;
printf("请保存!
\n");
}
}
}
1.2.7更改函数的设计
根据输入要更改的电器的名称,找到该电器的所有记录输出后提示输入新的数据,更改完后,返回主菜单并提示用户保存!
voidchange(linklist*l)//更改记录函数
{
charna[20];
linklist*p,*q;
q=l;
p=l->next;
inty;
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%10s\n","编号","名称","品牌","价格","数量");
printf("%10d%10s%10s%10d%10d\n",p->data.j,p->data.name,p->data.pai,p->data.price,p->data.number);
printf("请输入你修改记录的新信息:
\n");
printf("%10s%10s%10s%10s%10s\n","编号","名称","品牌","价格","数量");
scanf("%10d%10s%10s%10d%10d",&q->data.j,p->data.name,p->data.pai,&p->data.price,&p->data.number);
p=p->next;
}
}printf("修改成功!
请保存!
\n");
}
第2章软件测试
2.1函数模块的测试
2.1.1添加记录函数的测试
添加记录
2.1.2查询函数的测试
无记录时查询:
查询所有:
按名称查询:
退出查询系统:
输入0后,返回主菜单。
2.1.3删除函数的测试
2.2文件模块的测试
2.2.1文件读取的测试
无记录时的读取:
有记录时的读取:
2.2.2文件写入的测试
文件写入前:
添加新的记录并文件写入后:
第3章软件使用说明书
用户首先需要启动程序进入主菜单界面,下面分别是界面菜单的使用说明:
1.读取记录:
在此目录下,用户可以将库存文件记录读取并显示出来。
2.保存记录:
在此目录下,用户可以将记录保存到文件。
3.添加记录:
在此目录下,用户添加新的纪录。
添加完后,系统会返回主菜单并提示用户保存,此时你要可以选择2保存,如果不选择保存则不会保存。
4.删除纪录:
在此目录下,用户删除纪录。
删除后,系统会返回主菜单并提示用户保存,此时你要可以选择2保存,如果不选择保存则不会删除。
5.查询记录:
在此目录下,用户可以查询所有家电记录和按名称查询家电记录。
1.查询所有家电记录:
显示所有的家电记录,如果没有记录则会提示用户输入记录。
2.按名称查询家电记录:
输入要查询家电的名称后,显示相应家电的信息。
0.退出查询系统:
退出查询系统并返回主菜单。
6.更改记录:
在此目录下,用户在原有的记录上更改记录。
更改后,系统会返回主菜单并提示用户保存,此时你要可以选择2保存,如果不选择保存则不会更改。
0.退出系统:
提示按任意键退出系统。
第4章软件设计总结
一开始看到这个软件的设计要求,头都大了!
不知道从何下手。
后来在书上和网上查阅了很多资料,才找到了一点头绪。
在老师和同学的帮助下,才勉强完成了这个程序的设计。
其实说来,这个程序并不难,主要是链表的应用,链表并不是很难,只是平时自己没有真正的好好去学这门课,没有把这个当成一回事去做。
甚至还埋怨老师给我们出这么难的题目。
通过这次的课程设计,我知道了自己是多么无知,连最基础的东西都不会,更不要说学更难更深得东西了,自己要学的东西真的是太多太多了!
最后我要感谢老师的指导和教诲!
参考文献
[1]严蔚敏吴伟民数据结构(C语言版)清华大学出版社,2000
[2]文益民周学毛李健数据结构与程序设计人民邮电出版社2008
[3]谭浩强C程序设计(第三版)清华大学出版设2008
[4]林锐韩永泉高质量程序设计指南—C++/C语言第3版2007
附录(程序清单)
程序代码:
#include
#include
#include
#include
typedefstruct//结构体定义
{
charname[20];
charpai[20];
intprice;
intnumber;
intj;
structnode*next;
}elemtype;
typedefstructnode
{
elemtypedata;
structnode*next;
}linklist;
linklist*Initlist(linklist*p);
linklist*add(linklist*l);
voidlist0(linklist*l);
intlist(linklist*l);
voidlist1(linklist*l);
intStrCmp(charna[],charname[],inty);
voidBubbleSortList(linklist*p);
voiddellist(linklist*l);
voidchange(linklist*l);
voidwrite_file(linklist*l);
linklist*read_file(linklist*l);
intmain(void)//主函数
{
inty;
linklist*l;
chara;
l=Initlist(l);
while
(1)
{
printf("***************电器库存管理系统*******************\n\n");
printf("*********************菜单***************************\n\n");
printf("*=======================================================*\n");
printf("*1.读取记录*\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;
case'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");return0;break;
default:
printf("输入错误,请重新输入:
\n\n");
}
}
}
linklist*Initlist(linklist*p)
{
p=(linklist*)malloc(sizeof(linklist));
p->next=NULL;
returnp;
}
linklist*add(linklist*l)
{
printf("进行添加的操作!
\n");
intn,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%10s\n","编号","名称","品牌","价格","数量");
for(i=1;i<=n;i++)
{
printf("%8c",'');
q=(linklist*)malloc(sizeof(linklist));
q->data.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;
}
printf("\n添加记录成功\n");
printf("请保存!
\n");
returnl;
}
intlist(linklist*l)//查询菜单
{
chara;
charb='';
while
(1)
{
printf("\n***************查询******************\n");
printf("*************************菜单********************************\n");
printf("*=========================================================*\n");
printf("*1.查询所有家电记录*\n");
printf("*2.按名称查询家电记录*\n");
printf("*0.退出查询系统*\n");
printf("*---------------------------------------------------------*\n");
printf("请输入查询的方式:
\n");
a=getch();
switch(a)
{
case'0':
return0;break;
case'1':
list0(l);break;
case'2':
list1(l);break;
default:
printf("输入错误,请重新输入:
\n");
}
}
}
voidlist0(linklist*l)//查询所有函数
{
intj=1;
linklist*p;
p=l->next;
if(p==NULL)
{
printf("没有记录,请输入记录\n");
}
else
{
printf("\n按照单价的升序进行排序后全部的记录\n");
printf("%10s%10s%10s%10s%10s\n","编号","名称","品牌","价格","数量");
while(p!
=NULL)
{
printf("%10d%10s%10s%10d%10d\n",p->data.j,p->data.name,p->data.pai,p->data.price,p->data.number);
p=p->next;
j++;
}
}
}
voidlist1(linklist*l)//按名称查询函数
{
linklist*p;
p=l;
inty;
intj=1;
charna[20];
printf("请输入查询家电的名称:
");
scanf("%s",na);
pr
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构 课程设计 报告 电器 库存 管理 系统