ImageVerifierCode 换一换
格式:DOCX , 页数:54 ,大小:133.48KB ,
资源ID:5668466      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/5668466.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(仓库管理系统.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

仓库管理系统.docx

1、仓库管理系统*实践教学* 兰州理工大学计算机与通信学院2011年秋季学期面向对象课程设计题 目: 仓库管理系统 专业班级: 计算机科学与技术一班姓 名: 海发明 学 号: 10240102 指导教师: 年福忠 成 绩:_目 录摘 要-1序 言-2正 文-31.采用类c+语言定义相关的数据类型-52.各模块的伪码算法.-53.函数的调用关系图-124.调试分析-135.测试结果-136.源程序(带注释)-16总 结-28参考文献-30致 谢-31附 件 部分源程序代码-33摘 要本程序主要介绍了小型仓库货品管理的设计与基本功能的实现。通过对仓库基本功能的分析,该程序实现了对小型仓库管理的基本操作

2、。设计要求主要是货品入库、出库、增加、删除、查找及显示库存量等最基本功能操作。在课程设计过程中,对问题的所采用的数据结构和算法分析,及程序设计语言采用VC+,程序运行的平台WindowsXP(visual C+6.0),逐步对基本要求进行分布实现,在设计中采用单链表和文件对录入的基本数据进行存储,最终对产品进行的基本操作如产品入库、出库及查找都基本以实现。 关键字:c+,结构体,软件,插入;序 言 现代科学技术的飞速发展,改变了世界,也改变了人类的生活,作为新世纪的大学生,应当站在时代发展的前列,掌握现代科学技术知识,调整自己的知识结构和能力结构,以适应社会发展的要求。掌握计算机知识和应用,无

3、疑是培养新型人才的一个重要环节。对于我们计算机专业的学生来说,想要把所学知识用于实践,课程设计是一个很好的环节,课程设计不仅提高了我们的设计能力和操作能力,加深理解了数据的逻辑结构、存储结构,掌握线性表上基本运算的实现,进一步理解和熟练掌握课本中所学的各种数据结构,而且学会了如何把学到的知识用于解决实际问题。通过本次课程设计的制作,能让我们对数据结构以及程序设计有更深的体会,流程图的建立能提高我们系统分析问题的能力,从而灵活的驾驭整个程序的运行,对于具体问题,找出具体的解决方案或是多种解决方案,增强我们的创新能力。 正文1. 采用类c+语言定义相关的数据类型menu_init ()+新建仓库

4、newstore()+打开仓库 openstore()+添加货物 addproduct() +修改货物 editproduct() +删除货物 delproduct() +库存管理 menu_store()-货物出库 instore() -货物进库 outstore() +货物查询 menu_check() +按编号查询 bynumber() +按名称查询 byname() +储存数据 savedata()+所有货物 listall() +退出系统 exit()1.2数据设计商品结构体设计:struct Product int num; char name20; float price; in

5、t amount; char fac50; char buss50; struct *next; 2各模块的伪码算法:2.1菜单类:menu_init();说明:初始化界面menu_store();说明:库存管理界面menu_check();说明:货物查询界面menu exit();说明:退出界面2.2货物管理类:addproduct( struct Product *head );说明: struct Product *head 为要添加节点的链表功能:添加货物流程图:editproduct( struct Product *head );说明: struct Product *head 为

6、要修改节点的链表功能:修改货物流程图:delproduct( struct Product *head );说明: struct Product *head 为要修改节点的链表功能:删除货物流程图:instore( struct Product *head );说明: struct Product *head 为要修改节点的链表功能:修改货物outstore( struct Product *head );说明: struct Product *head 为要修改节点的链表功能:修改货物outinstore( struct Product *head, int ouin );说明: struc

7、t Product *head 为要修改节点的链表功能:出库进库综合操作类2.3货物查询类:bynumber( struct Product *head, int num );说明: struct Product *head 为要修改节点的链表, num 为商品编号功能:按编号查询商品byname( struct Product *head, char *name );说明: struct Product *head 为要修改节点的链表, name 为商品名称功能:按名称查询商品listall( struct Product *head );说明: struct Product *head 为

8、要显示链表功能:显示所有商品流程图:2.4仓库管理类:openstore( );说明: 打开仓库数据文件到链表功能:打开仓库文件NS流程图:struct Product *h = NULL;filename01.2 1.4 1.6 1.7 1.8 1.9 1.10 2.1 2.4 3.1 3.2 3.5 4.1 4.2 4.3 5.1 5.2 5.3 5.4 6.2 6.3 输入文件名filenamefp = fopen (filename,”rb”)TFwhile( !feof(fp) )fread( pd, Length, 1, fp )Freturn h;return h;q = pd;

9、pd = pd -next;break;q-next; return h;savedata( );说明: 写仓库链表数据到文件功能:储存货品数据2.5辅助类:cls( );说明: 换行功能:换行3.函数的调用关系图:四、五、调试分析与结果:1 程序运行时初始界面2 新建仓库用键盘输入1,程序调用新建仓库功能函数,要求用户输入货物编号,货物名称,货物价格等。3 打开仓库文件用键盘输入2,程序调用打开仓库文件功能函数,要求用户输入仓库数据文件名,数据文件存在,显示打开成功。4 添加货物用键盘输入3,程序调用添加货物功能函数,要求用户输入货物编号,货物名称,货物价格等。5 修改货物用键盘输入4,程序

10、调用修改货物功能函数,要求用户输入货物编号,货物存在,显示货物详细信息,按任意键后,要求用户输入新货物名称,货物价格等。6 删除货物用键盘输入5,程序调用删除货物功能函数,要求用户输入货物编号,货物存在,显示货物详细信息,按任意键后,删除货物。7 库存管理:用键盘输入6,程序调用库存管理功能函数,显示库存管理子页面,选择2,货物出库,要求用户输入货物编号,货物存在,显示货物详细信息,要求用户输入进库数量。8 货物查询用键盘输入7,程序调用货物查询功能函数,显示货物查询子页面,选择1,按编号查询,要求用户输入货物编号,货物存在,显示货物详细信息。货若物不存在,显示“没有该编号货物”。9 储存数据

11、用键盘输入8,程序调用储存数据功能函数,要求用户输入文件名,将数据储存在指定文件中。10 所有货物用键盘输入9,程序调用所有货物功能函数,显示仓库内所有货物。11 退出系统用键盘输入0,程序调用货退出系统功能函数,显示提示保存信息。6.源程序(带注释):#include #include #include #include #define Length sizeof( struct Product )struct Product /定义货品结构体 int num; /编号 char name20; /名称 float price; /价格 int amount; /库存数量 char fac5

12、0; /生产厂家 char buss50; /提供商家 struct Product *next;void cls( void ) int i; for( i=0; inum,&pd-name,&pd-price,&pd-amount,&pd-fac,&pd-buss)=NULL) break; pd-next = (struct Product *)malloc( Length ); if( pd-next = NULL ) printf(内存溢出n); / getch(); return(h); q = pd; pd = pd-next; q-next = NULL; fclose( fp

13、 ); printf(成功打开仓库数据文件n); / getch(); return(h);int savedata( struct Product *head ) char filename255; struct Product *pd; FILE *fp; pd = head; printf(请输入要保存的仓库数据文件名(如:D:/store.txt,0取消):n); scanf(%s, &filename); if( filename0 = 0 ) return 1; if( (fp=fopen(filename, wb) ) = NULL ) printf(储存文件出错n); / ge

14、tch(); return 1; printf(正在储存数据.n); while( pd!=NULL ) fprintf( fp, %dt%st%ft%dt%st%sn,pd-num,pd-name,pd-price,pd-amount,pd-fac,pd-buss); pd = pd-next; fclose( fp ); printf(仓库数据保存成功n); / getch(); return 0;/创建链表,新建一个仓库,并输入数据/返回链表struct Product *newstore() struct Product *h = NULL, *pd; for(;) pd = (str

15、uct Product *)malloc( Length ); if (!pd) printf(内存溢出!n); / getch(); return NULL; printf(请输入货品编号(0退出):n); scanf(%d, &pd-num); if( pd-num = 0 ) break; printf(请输入货品名称:n); scanf(%s, &pd-name); printf(请输入货品价格:n); scanf(%f, &pd-price); printf(请输入货品库存量:n); scanf(%d, &pd-amount ); printf(请输入货品的生产厂家:n); scan

16、f(%s,&pd-fac); printf(请输入货品的提供商家:n); scanf(%s,&pd-buss); printf(n); pd-next = h; h = pd; return(h);/添加货品,向链表末尾添加货品/参数:*head链表指针/返回添加货品的链表struct Product *addproduct( struct Product *head ) struct Product *h, *pd; if( !head ) printf(请先创建或打开仓库n); return head; else h = head; for(;) pd = (struct Product

17、*)malloc( Length ); if (!pd) printf(内存溢出!n); / getch(); break; printf(请输入货品编号(0退出):n); scanf(%d, &pd-num); if( pd-num = 0 ) break; printf(请输入货品名称:n); scanf(%s, &pd-name); printf(请输入货品价格:n); scanf(%f, &pd-price); printf(请输入货品库存量:n); scanf(%d, &pd-amount ); printf(请输入货品的生产厂家:n); scanf(%s,&pd-fac); pri

18、ntf(请输入货品的提供商家:n); scanf(%s,&pd-buss); printf(n); while( h-next!=NULL ) h = h-next; h-next = pd; pd-next = NULL; return(h);/按编号查找货品/参数:*head链表指针,*num货品编号/返回:链表结点struct Product *bynumber( struct Product *head, int num ) float total; int n = num; struct Product *pd; pd = head; while( pd!=NULL&pd-num!=

19、n) pd = pd-next; if( pd = NULL) printf(没有该编号货品。n); / getch(); else printf(*按编号查询货品*n); printf(| 编号 | 名称 | 价格 | 库存 | 生产厂家 | 提供商家 | 价值量 |n); printf(|-|-|-|-|-|-|-|n); printf(|%6d|%-13s|%-9.3f|%-8d|%-10s|%-10s|,pd-num,pd-name,pd-price,pd-amount,pd-fac,pd-buss); total = pd-price * pd-amount; printf(%-10

20、.3f|n, total); printf(*n); / getch(); return(pd);/按名称查找货品/参数:*head链表指针,*name货品名称/返回:链表结点struct Product *byname( struct Product *head, char name20 ) float total; struct Product *pd; pd = head; while( pd!=NULL&strcmp(pd-name, name)!=0) /查找货品 pd = pd-next; if( pd = NULL) printf(没有该名称货品。n); / getch(); e

21、lse printf(*按名称查询货品*n); printf(| 编号 | 名称 | 价格 | 库存 | 生产厂家 | 提供商家 | 价值量 |n); printf(|-|-|-|-|-|-|-|n); printf(|%6d|%-13s|%-9.3f|%-8d|%-10s|%-10s|, pd-num, pd-name, pd-price, pd-amount,pd-fac,pd-buss); total = pd-price * pd-amount; printf(%-10.3f|n, total); printf(*n); / getch(); return(pd); void *che

22、ckbynumber( struct Product *head ) struct Product *h = head; int num; printf(请输入查询编号(0退出):n); scanf(%d, &num); return bynumber( h, num); void *checkbyname( struct Product *head ) struct Product *h = head; char name20; printf(请输入货品名称(0退出):n); scanf(%s, &name); return byname( h, name);/修改货品/参数:*head链表指针/返回:链表结点struct Product *editproduct( struct Product *head ) int num; str

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

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