1、在程序设计阶段应尽量利用已有的标准函数,加大代码的重用率。 2、设计的题目要求到达一定工作量200行以上代码,并具有一定的深度。3、程序设计语言推荐使用C,程序书写标准,源程序需加必要的注释并且缩进一致。4、每位同学需提交可独立运行的程序;5、每位同学需独立提交设计报告书每人一份,要求编排格式统一、标准、内容充实,不少于0页代码不算;6、课程设计实践作为培养学生动手能力的一种手段,单独考核。3课程设计说明书一 需求分析 现阶段快速的社会开展要求高速的完成任何事情。在各个市场,特别在超市,管理员对货物的高效管理显得尤为重要。不仅客户希望快速,准确的查询到购置的货物信息,管理员也希望能方便的管理货
2、物,给客户提供满意的效劳。因此,本程序就可以完成统计并管理货物信息的任务。实现了统计每个货物的信息,然后可以轻松地通过对货物编号的排序快速的去找到想要查询的货物,然后就可以实现对货物的修改、删除、添加等功能。 本程序的宗旨在于提高管理者的工作效率,方便管理者及客户进行查询,实现精确地管理货物目的。二 系统设计该程序设计主要运用了c语言的根本知识,通过调用各个函数实现整个完整的系统功能。该仓库管理系统主要实现了管理员和用户两种不同身份的功能,以下就是程序实现的主要功能:管理员的功能: 用户的功能: 0:显示菜单 :读取信息 :录入信息 2:查询信息 2:查询信息 3:退出系统 3:修改信息4:添
3、加信息 5:删除信息 6:正向排序7:输出信息8:保存信息9:有功能模块图和流程图 功能模块图:仓库货物管理系统管理员用户输入密码 退出系统 否 查询信息 读取信息是否正确? 是 退出系统 保存信息 输出信息 正向排序 删除信息 添加信息 修改信息 录入信息显示菜单 开 始流程图:是否是管理员? 是密码是否正确? 是 菜单项选择择 查询信 息录入信息输入编号 选择添加方式输入信息排序完毕输入添加内容查询完毕 删除完毕选择修改内容输入完毕 添加完毕输入修改信息 修改完毕保 存 信 息 读 取 信 息 退 出 系 统结 束三 详细设计 、首先写入头文件#includestdlib.hstring.
4、hwindows.h#define M sizeof(struct goods)2、定义一个结构体存储货物的信息struct goods int num; char name20; float price; int amount; struct goods *next;3、 输入货物信息函数struct goods *create() int i; struct goods *head,*p,*q; p=q=head=NULL; printf(请输入货物的编号 名称 价格 数量n); for(i=;i+) p=(struct goods *)malloc(sizeof(struct goods
5、); scanf(%d %s %f %d,&pnum,pname,&price,&amount); if(i=) head=p; else qnext=p; q=p; if(pnum=0) break; next=NULL; return head;4、查找货物信息函数void find(struct goods *head,int num) struct goods *p; p=head; int i=0; while(p!=NULL) num=num) i=;%d %s %.2f %dn,pname,pprice,p查找货物编号成功 p=pnext; if(i=0)没有查到货物编号n5、修
6、改信息函数 void change(struct goods *head,int num) struct goods *p2; p2=head; int j; while(p2!=NULL) if(p2num=num) printf(你想修改货物的.编号 2.名称 3.价格 4.数量 5.全部修改?n%dj); switch(j) case :printf(请输入修改的货物的编号:scanf(p2num);修改货物信息成功nbreak; case 2:请输入修改的货物的名称:%s,p2name); case 3:请输入修改的货物的价格:%fprice); case 4:请输入修改的货物的数量:
7、 case 5:请输入修改的货物的编号 名称 价格 数量:num,p2 default :error! p2=p2没有找到要修改的货物编号n6、添加货物信息函数头插法struct goods *add(struct goods *head) struct goods *p3,*pm; pm=head; p3=(struct goods *)malloc(sizeof(struct goods);请添加货物的编号 名称 价格 数量np3num,p3 while(pm! while(pmnum=p3num) 已有此货物编号n scanf( pm=pm p3next=head; head=p3;添加
8、信息成功n2添加货物信息函数非头插法struct goods *add2(struct goods *head,int num) struct goods *p4,*p5; p5=head; p4=(struct goods *)malloc(sizeof(struct goods);p4num,p4 while(p5! while(p5num=p4num) if(p5num!=p4 p5=p5 p4next=p5 p5next=p4;7、删除货物信息函数struct goods *del(struct goods *head,int num) struct goods *p3,*p4; p3=p4=head; while(p3next! p4=p3; p3=p3 if(p3next=p3 free(p3);删除货物信息成功n没有找到要删除的货物n8、 正向排序函数 struct goods *sort(struct goods *head) struct goods *p,*q,*a,*b,*newhead; newhead=NULL; int max; while(head! q=head a=head; b=NULL; max=pnum; while(q! if(qnummax) max=q a=q;
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1