C语言程序设计超市管理系统

上传人:s9****2 文档编号:429717971 上传时间:2023-02-26 格式:DOC 页数:23 大小:171.01KB
返回 下载 相关 举报
C语言程序设计超市管理系统_第1页
第1页 / 共23页
C语言程序设计超市管理系统_第2页
第2页 / 共23页
C语言程序设计超市管理系统_第3页
第3页 / 共23页
C语言程序设计超市管理系统_第4页
第4页 / 共23页
C语言程序设计超市管理系统_第5页
第5页 / 共23页
点击查看更多>>
资源描述

《C语言程序设计超市管理系统》由会员分享,可在线阅读,更多相关《C语言程序设计超市管理系统(23页珍藏版)》请在金锄头文库上搜索。

1、 程序设计超市管理系统 学院: 专业: 班级: 姓名: 学号: 指导老师: 超市管理系统课程设计1)需求分析:设计题目:超市管理系统设计要求:有一个小型超市,出售N(N10)种商品,设计并实现一个系统系统功能需求分析:1 保存及输出:超市中的各种商品信息保存在指定文件中,可以把它们输出显示。2 计算并排序:计算每类商品的总价值(sum,单精度)及平均价(aver,单精度,输出一位小数),将每类商品按平均价从大到小的顺序排序打印出来。3 统计:统计输出库存量低于100的货号及类别。统计输出有两种以上(含两种)商品库存量低于100的商品类别。2)概要设计:系统总体设计框架:主模块信息输出修改模块新

2、建信息模块排序模块计算模块统计模块1统计模块2打印模块系统功能模块图:主模块信息输出修改模块新建信息模块排序模块统计模块1统计模块2打印模块添加商品主模块商品价格(从高到低)删除某商品信息修改某商品信息主模块信息输出计算模块商品信息平均价3)详细设计:主要功能模块的算法设计思路:本程序主要分为八个模块:主模块、信息输出修改模块、新建信息模块、排序模块、计算模块、统计模块1、统计模块2、打印模块。1) 主模块:通过调用各分模块实现功能;2) 信息输出修改模块:输出显示文件中商品信息内容,添加商品信息,删除商品信息,修改商品信息;3) 新建商品信息模块:建立一个新结构体,为链表存信息用,并且将信息

3、保存在指定的文件中;4) 排序模块:把文件中顺序零乱的商品信息按单价的大小从高到低进行排序,放到链表里存储;5) 计算模块:将所有商品的价格与库存量进行累加求和;6) 打印模块:将商品信息按每类平均价格排序(从高到低)按顺序打印出来;7) 统计模块1:统计库存量低于100的货名及类别;8) 统计模块2:统计商品库存量有2种以上(含2种)低于100的商品类别工作流程图:开始输出商品信息或修改商品信息新建商品信息(删除原有信息)统计商品信息退出输入商品信息(编号、名称、类型、价格、单位、数目)结束输入添加商品信息修改某商品信息删除某商品信息确认或取消输入商品单价和库存量返回输出(商品类型、平均价、

4、总库存量)排序(按价格从高到低)4)主要源程序代码:#include stdio.h /*输入,输出头文件*/ #include stdlib.h /*申请空间头文件*/ #include string.h /*对字符串加工头文件*/ #include conio.h /*清屏头文件*/ FILE *fp;int n=0; /*定义文件指针类型*/int i,j,a4,m; /*定义整数类型*/ float aver4,sum4,g4,h; /*定义浮点类型*/ char c5=elec; /*定义字符数组类型*/char d5=comm; /*定义字符数组类型*/char e5=food;

5、/*定义字符数组类型*/char f5=offi; /*定义字符数组类型*/struct good /*定义结构体*/ int num; /*商品编号*/ char name20; /*商品名称*/ char kind40; /*商品类型*/ float price; /*商品价格*/ char unit10; /*商品单位*/ int quantity; /*商品数量*/ struct good *next; /*定义结构体指针类型*/*head,*p1,*p2;struct good *createlist() /*创建链表函数*/ struct good *head1,*p1,*p2;

6、/*定义结构体指针类型*/ if(fp=fopen(goods message.txt,w)=NULL) /*判断能否打开文件*/ printf(can not open the file); exit(0); /*结束程序*/ head1=(struct good *)malloc(sizeof(struct good); /*申请头结点空间*/ p1=head1; p2=head1; printf(*n); printf(请输入信息:编号,名称,类型,价格,单位,数目n); printf( (以输入“1”表示结束输入)n); printf(*n); printf(_n); scanf(%d

7、 %s %s %f %s %d,&p1-num,p1-name,p1-kind,&p1-price,p1-unit,&p1-quantity); /*输入商品信息*/ printf(_n); p1-next=NULL; fprintf(fp,%d %s %s %f %s %d ,p1-num,p1-name,p1-kind,p1-price,p1-unit,p1-quantity); /*将商品信息写入文件*/ while(1) p1=(struct good *)malloc(sizeof(struct good); /*申请新空间*/ printf(*n); printf(请输入信息:编号

8、,名称,类型,价格,单位,数目n); printf( (以输入“1”表示结束输入)n); printf(*n); printf(_n); scanf(%d,&p1-num); if(p1-num=-1) /*申请空间结束条件*/ printf(_nn); fprintf(fp,%d,-1); fclose(fp); return head1; /*返回头指针*/ scanf(%s %s %f %s %d,p1-name,p1-kind,&p1-price,p1-unit,&p1-quantity); /*输入商品信息*/ printf(_n); fprintf(fp,%d %s %s %f %

9、s %d ,p1-num,p1-name,p1-kind,p1-price,p1-unit,p1-quantity); /*将商品信息写入文件*/ p1-next=NULL; p2-next=p1; p2=p1; struct good *paixu(struct good*head2) /*链表排序函数*/ struct good *p6,*p7,*r,*s; /*定义结构体指针类型*/ for(i=0;inext=head2; head2=p6; while(p6-next!=NULL) /*判断循环结束条件*/ p7=p6-next; r=p6; while(p7-next!=NULL)

10、 /*判断循环结束条件*/ if(p7-next-price)(r-next-price) /*判断是否调换*/ r=p7; p7=p7-next; if(p6!=r) /*判断循环结束条件*/ s=r-next; /*指针调换*/ r-next=s-next; s-next=p6-next; p6-next=s; p6=p6-next; p6=head2; head2=head2-next; free(p6); /*释放第一个无效空间*/ return head2; void jisuan() p1=head; do if(strcmp(p1-kind,c)=0) /*判断是否为电器类型*/ sum0=sum0+(p1-price)*(p1-quantity); /*求电器总价*/ a0=a0+p1-quantity; /*求电器总件数*/ if(strcmp(p1-kind,d)=0) /*判断是否为日用品类型*/ sum1=sum1+(p1-price)*(p1-quantity); /*求日用品总价*/ a1=a1+p1-quantity; /*求日用品总件数*/ if(strcmp(p1-kind,e)=0) /*判断是否为办公用品类型*/ sum2=sum2+(p1-price)*(p1-quantity); /*求办公用品总价*

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 机械/制造/汽车 > 汽车技术

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号