C语言--超市管理系统源程序.doc

上传人:豆**** 文档编号:23956349 上传时间:2022-07-02 格式:DOC 页数:76 大小:449.50KB
返回 下载 相关 举报
C语言--超市管理系统源程序.doc_第1页
第1页 / 共76页
C语言--超市管理系统源程序.doc_第2页
第2页 / 共76页
点击查看更多>>
资源描述

《C语言--超市管理系统源程序.doc》由会员分享,可在线阅读,更多相关《C语言--超市管理系统源程序.doc(76页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、Four short words sum up what has lifted most successful individuals above the crowd: a little bit more.-author-dateC语言-超市管理系统源程序C语言-超市管理系统源程序C语言超市管理系统源程序超市管理系统源程序代码,要可以执行的。最好是文件,链表中的一种。好了一定重金酬谢 最佳答案 有一个小型超市,出售N(N10)种商品,设计并实现一个系统,完成下列功能:1 保存及输出。超市中的各种商品信息保存在指定文件中,可以把它们输出显示。2 计算并排序。计算每类商品的总价值(sum,单精度)

2、及平均价(aver,单精度,输出一位小数),将每类商品按平均价从大到小的顺序排序打印出来。3 统计。统计输出库存量低于100的货号及类别。统计输出有两种以上(含两种)商品库存量低于100的商品类别。1.2总体结构 本程序主要分为八个模块:主模块、信息输出修改模块、新建信息模块、排序模块、计算模块、统计模块1、统计模块2、打印模块。1) 主模块:通过调用各分模块实现功能;2) 信息输出修改模块:输出显示文件中商品信息内容,添加商品信息,删除商品信息,修改商品信息;3) 新建商品信息模块:建立一个新结构体,为链表存信息用,并且将信息保存在指定的文件中;4) 排序模块:把文件中顺序零乱的商品信息按单

3、价的大小从高到低进行排序,放到链表里存储;5) 计算模块:将所有商品的价格与库存量进行累加求和;6) 打印模块:将商品信息按每类平均价格排序(从高到低)按顺序打印出来;7) 统计模块1:统计库存量低于100的货名及类别;8) 统计模块2:统计商品库存量有2种以上(含2种)低于100的商品类别。附 录(程序清单)#include stdio.h /*输入,输出头文件*/ #include stdlib.h /*申请空间头文件*/ #include string.h /*对字符串加工头文件*/ #include conio.h /*清屏头文件*/ FILE *fp;int n=0; /*定义文件指

4、针类型*/int i,j,a4,m; /*定义整数类型*/ float aver4,sum4,g4,h; /*定义浮点类型*/ char c5=elec; /*定义字符数组类型*/char d5=comm; /*定义字符数组类型*/char e5=food; /*定义字符数组类型*/char f5=offi; /*定义字符数组类型*/struct good /*定义结构体*/ int num; /*商品编号*/ char name20; /*商品名称*/ char kind40; /*商品类型*/ float price; /*商品价格*/ char unit10; /*商品单位*/ int

5、quantity; /*商品数量*/ struct good *next; /*定义结构体指针类型*/*head,*p1,*p2;struct good *createlist() /*创建链表函数*/ struct good *head1,*p1,*p2; /*定义结构体指针类型*/ if(fp=fopen(goods message.txt,w)=NULL) /*判断能否打开文件*/ printf(can not open the file); exit(0); /*结束程序*/ head1=(struct good *)malloc(sizeof(struct good); /*申请头结

6、点空间*/ p1=head1; p2=head1; printf(*n); printf(请输入信息:编号,名称,类型,价格,单位,数目n); printf( (以输入“1”表示结束输入)n); printf(*n); printf(_n); scanf(%d %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-pric

7、e,p1-unit,p1-quantity); /*将商品信息写入文件*/ while(1) p1=(struct good *)malloc(sizeof(struct good); /*申请新空间*/ printf(*n); printf(请输入信息:编号,名称,类型,价格,单位,数目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 head

8、1; /*返回头指针*/ scanf(%s %s %f %s %d,p1-name,p1-kind,&p1-price,p1-unit,&p1-quantity); /*输入商品信息*/ printf(_n); fprintf(fp,%d %s %s %f %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 *p

9、6,*p7,*r,*s; /*定义结构体指针类型*/ for(i=0;inext=head2; head2=p6; while(p6-next!=NULL) /*判断循环结束条件*/ p7=p6-next; r=p6; while(p7-next!=NULL) /*判断循环结束条件*/ 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;

10、 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+p

11、1-quantity; /*求日用品总件数*/ if(strcmp(p1-kind,e)=0) /*判断是否为办公用品类型*/ sum2=sum2+(p1-price)*(p1-quantity); /*求办公用品总价*/ a2=a2+p1-quantity; /*求办公用品总件数*/ if(strcmp(p1-kind,f)=0) /*判断是否为食品类型*/ sum3=sum3+(p1-price)*(p1-quantity); /*求食品总价*/ a3=a3+p1-quantity; /*求食品总件数*/ p1=p1-next; while (p1!=NULL); /*遍历链表结束条件*/

12、 for(i=0;inum,p3-name,p3-kind,&p3-price,p3-unit,&p3-quantity); /*从文件中写到链表*/ while(1) p4=(struct good *)malloc(sizeof(struct good); /*申请头结点空间*/ fscanf(fp,%d ,&p4-num); if(p4-num!=-1) /*判断循环结束条件*/ fscanf(fp,%s %s %f %s %d ,p4-name,p4-kind,&p4-price,p4-unit,&p4-quantity); /*从文件中写到链表*/ p4-next=NULL; p3-

13、next=p4; p3=p4; else p3-next=NULL; break; fclose(fp); /*关闭文件*/ p3=head; while(p3!=NULL) printf( %d %s %s %0.1f %s %dnn,p3-num,p3-name,p3-kind,p3-price,p3-unit,p3-quantity); printf(_n); p3=p3-next; printf(*n); printf(/n); while(n!=4) p3=head; printf(*n); printf(1 添加商品信息n); printf(2 删除某商品信息n); printf(

14、3 修改某商品信息n); printf(4 返回(当你完成了对某一商品的添加、删除或者修改后请按4返回)n); printf(*n); scanf(%d,&n); if(n=1) /*添加商品信息*/ printf(请输入商品 编号 名称 类型 价格 单位 数目n); printf(*n); p4=(struct good *)malloc(sizeof(struct good); /*申请空间*/ scanf(%d %s %s %f %s %d,&p4-num,p4-name,p4-kind,&p4-price,p4-unit,&p4-quantity); /*输入商品信息*/ p4-nex

15、t=NULL; while(p3-next!=NULL) /*判断循环结束条件*/ p3=p3-next; p3-next=p4; p3=head; if(fp=fopen(goods message.txt,w)=NULL) /*判断能否打开文件*/ printf(can not open the file); exit(0); /*结束程序*/ while(p3!=NULL) fprintf(fp,%d %s %s %f %s %d ,p3-num,p3-name,p3-kind,p3-price,p3-unit,p3-quantity) /*将商品信息写入文件*/ p3=p3-next;

16、 fprintf(fp,%d,-1); fclose(fp); /*关闭文件*/ printf(*n); printf(_n); printf(-请按4返回-n); printf(_n); printf(*n); if(n=2) /*删除商品*/ printf(*n); printf(请输入需要删除的商品编号n); printf(*n); scanf(%d,&p); printf(*n); printf(1 确认删除n2 取消删除n); printf(*n); scanf(%d,&r); if(r=1) if(head-num)=p) head=head-next; free(p3); /*释

17、放空间*/ else p4=head; p3=p4-next; while(p3!=NULL) /*判断循环结束条件*/ if(p3-num)=p) p5=p3-next; free(p3); /*释放空间*/ p4-next=p5; break; p3=p3-next; p4=p4-next; if(fp=fopen(goods message.txt,w)=NULL) /*判断能否打开文件*/ printf(can not open the file); exit(0); /*结束程序*/ p3=head; while(p3!=NULL) /*判断循环结束条件*/ fprintf(fp,%

18、d %s %s %f %s %d ,p3-num,p3-name,p3-kind,p3-price,p3-unit,p3-quantity); /*将商品信息写入文件*/ p3=p3-next; fprintf(fp,%d,-1); fclose(fp); /*关闭文件*/ if(r=2) continue; /*继续循环*/ printf(*n); printf(_n); printf(-请按4返回-n); printf(_n); printf(*n); if(n=3) /*修改某商品信息*/ printf(请输入需要修改的商品编号n); scanf(%d,&q); while(p3!=NU

19、LL) /*判断循环结束条件*/ if(p3-num)=q) /*判断是否为所需要修改的商品*/ printf(请输入商品单价与库存量(如果单价不变请输入原来的单价)n); scanf(%f %d,&p3-price,&p3-quantity); /*输入商品价格与库存量*/ p3=p3-next; if(fp=fopen(goods message.txt,w)=NULL) /*判断能否打开文件*/ printf(can not open the file); exit(0); /*结束程序*/ p3=head; while(p3!=NULL) /*判断循环结束条件*/ fprintf(fp

20、,%d %s %s %f %s %d ,p3-num,p3-name,p3-kind,p3-price,p3-unit,p3-quantity); /*将商品信息写入文件*/ p3=p3-next; fprintf(fp,%d,-1); fclose(fp); /*关闭文件*/ printf(*n); printf(_n); printf(-请按4返回-n); printf(_n); printf(*n); if(n=4) /*退出*/ break; printf(*n); printf(1 继续修改n-n2 返回n); printf(*n); scanf(%d,&p); if(p=1) co

21、ntinue; /*继续循环*/ if(p=2) break; /*跳出循环*/ while(n!=2); fclose(fp); /*关闭文件*/void printf0(struct good *p) /*遍历链表并打印电器类商品函数*/ struct good *p3; /*定义结构体指针类型*/ p3=p; while (p3!=NULL) /*判断遍历链表循环结束条件*/ if(strcmp(p3-kind,c)=0) /*判断商品类型是否为电器类型*/ printf(%dt%st%st%0.1ft%st%dn,p3-num,p3-name,p3-kind,p3-price,p3-u

22、nit,p3-quantity); /*输出电器类商品信息*/ printf(_n); p3=p3-next; return;void printf1(struct good *p) /*遍历链表并打印日用品类商品函数*/ struct good *p3; /*定义结构体指针类型*/ p3=p; while (p3!=NULL) /*判断遍历链表循环结束条件*/ if(strcmp(p3-kind,d)=0) /*判断商品类型是否为日用品类型*/ printf(%dt%st%st%0.1ft%st%dn,p3-num,p3-name,p3-kind,p3-price,p3-unit,p3-qu

23、antity); /*输出日用品类商品信息*/ printf(_n); p3=p3-next; return;void printf2(struct good *p) /*遍历链表并打印办公用品类商品函数*/ struct good *p3; /*定义结构体指针类型*/ p3=p; while (p3!=NULL) /*判断遍历链表循环结束条件*/ if(strcmp(p3-kind,e)=0) /*判断商品类型是否为办公用品类型*/ printf(%dt%st%st%0.1ft%st%dn,p3-num,p3-name,p3-kind,p3-price,p3-unit,p3-quantity

24、); /*输出办公用品类商品信息*/ printf(_n); p3=p3-next; return;void printf3(struct good *p) /*遍历链表并打印食品类商品函数*/ struct good *p3; /*定义结构体指针类型*/ p3=p; while (p3!=NULL) /*判断遍历链表循环结束条件*/ if(strcmp(p3-kind,f)=0) /*判断商品类型是否为食品类型*/ printf(%dt%st%st%0.1ft%st%dn,p3-num,p3-name,p3-kind,p3-price,p3-unit,p3-quantity); /*输出食品

25、类商品信息*/ printf(_n); p3=p3-next; return;void shunxudayin() for(i=0;i4;i+) gi=averi; /*将平均价赋给新数组*/ for(j=0;j3;j+) /*将新数组用冒泡排序法排序*/ for(i=j+1;i4;i+) if(gjgi) h=gj; gj=gi; gi=h; printf(n*n); printf(商品平均价格排序表(从高到低)n); printf(*n); printf(_n); printf(编号t名称t类别t单价t单位t数量n); printf(_n); for(j=0;j4;j+) for(i=0;iquantityname,p1-kind); /*输出商品名称及类别*/ printf(_n); p1=p1-next; void tongji2() printf(n*n); printf(商品库存量有2种以上(含2种)低于100的商品类别:n); printf(*n); printf(_n); if(a0=2) /*判断电器类库存量是否为2种以上(含2种)低于100*/ printf(电器n); printf(_n); if(a1=2)

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

当前位置:首页 > 教育专区 > 小学资料

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

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁