欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > DOCX文档下载  

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

    • 资源ID:3060776       资源大小:41.29KB        全文页数:20页
    • 资源格式: DOCX        下载积分:6.99金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要6.99金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

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

    C语言 超市管理系统源程序C语言超市管理系统源程序 超市管理系统源程序代码,要可以执行的。最好是文件,链表中的一种。好了一定重金酬谢 最佳答案 有一个小型超市,出售N种商品,设计并实现一个系统,完成下列功能: 1 保存及输出。超市中的各种商品信息保存在指定文件中,可以把它们输出显示。 2 计算并排序。计算每类商品的总价值及平均价,将每类商品按平均价从大到小的顺序排序打印出来。 3 统计。统计输出库存量低于100的货号及类别。统计输出有两种以上商品库存量低于100的商品类别。 1.2总体结构 本程序主要分为八个模块:主模块、信息输出修改模块、新建信息模块、排序模块、计算模块、统计模块1、统计模块2、打印模块。 1) 主模块:通过调用各分模块实现功能; 2) 信息输出修改模块:输出显示文件中商品信息内容,添加商品信息,删除商品信息,修改商品信息; 3) 新建商品信息模块:建立一个新结构体,为链表存信息用,并且将信息保存在指定的文件中; 4) 排序模块:把文件中顺序零乱的商品信息按单价的大小从高到低进行排序,放到链表里存储; 5) 计算模块:将所有商品的价格与库存量进行累加求和; 6) 打印模块:将商品信息按每类平均价格排序按顺序打印出来; 7) 统计模块1:统计库存量低于100的货名及类别; 8) 统计模块2:统计商品库存量有2种以上低于100的商品类别。 附 录 #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" /*定义字符数组类型*/ 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; /*定义结构体指针类型*/ 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(" 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->price,p1->unit,p1->quantity); /*将商品信息写入文件*/ while(1) p1=(struct good *)malloc(sizeof(struct good); /*申请新空间*/ printf("*n"); printf("请输入信息:编号,名称,类型,价格,单位,数目n"); printf(" 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 %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;i<=3;i+) /*赋初值值*/ ai=0; sumi=0; averi=0; p6=(struct good *)malloc(sizeof(struct good); /*申请新空间*/ p6->next=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; 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); /*求办公用品总价*/ 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); /*遍历链表结束条件*/ for(i=0;i<4;i+) averi=sumi/ai; /*求每类商品平均价*/ printf("*n"); printf("商品类型 t 平均价t 总库存量n"); printf("*n"); printf("_n"); printf("电器总价值:%0.1ft平均价:%0.1ft总库存量:%dn",sum0,aver0,a0); printf("_n"); printf("日用品总价值:%0.1ft平均价:%0.1ft总库存量:%dn",sum1,aver1,a1); printf("_n"); printf("食品总价值:%0.1ft平均价:%0.1ft总库存量:%dn",sum2,aver2,a2); printf("_n"); printf("办公用品总价值:%0.1ft平均价:%0.1ft总库存量:%dn",sum3,aver3,a3); printf("_n"); void shuchu /*输出商品信息函数*/ do struct good *p3,*p4,*p5; /*定义结构体指针类型*/ int n=0,p=0,q=0,r=0; printf("所有商品信息:n"); printf("编号,名称,类型,价格,单位,数目n"); printf("*n"); if(fp=fopen("goods message.txt","rb+")=NULL) /*判断能否打开文件*/ printf("can not open the file"); exit(0); /*结束程序*/ head=(struct good *)malloc(sizeof(struct good); /*申请头结点空间*/ p3=head; fscanf(fp,"%d %s %s %f %s %d ",&p3->num,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->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("3 修改某商品信息n"); printf("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->next=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 ",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=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); /*释放空间*/ else p4=head; p3=p4->next; %s %d /*将商品 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,"%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!=NULL) /*判断循环结束条件*/ 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,"%d %s %s %f ",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) continue; /*继续循环*/ if(p=2) break; /*跳出循环*/ while(n!=2); fclose(fp); /*关闭文件*/ %s %d /*将商品信 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->unit,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->quantity); /*输出日用品类商品信息*/ 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); /*输出办公用品类商品信息*/ 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); /*输出食品类商品信息*/ printf("_n"); p3=p3->next; return; void shunxudayin for(i=0;i<4;i+) gi=averi; /*将平均价赋给新数组*/ for(j=0;j<3;j+) /*将新数组用冒泡排序法排序*/ for(i=j+1;i<4;i+) if(gj<gi) 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;j<4;j+) for(i=0;i<4;i+) if (averi=gj) /*判断每类商品平均价格的先后顺序*/ switch(i) case 0: printf0(head); /*调用遍历链表并打印电器类商品函数*/ break; case 1: printf1(head); /*调用遍历链表并打印日用品类商品函数*/ break; case 2: printf2(head);/*调用遍历链表并打印办公用品类商品函数*/ break; case 3: printf3(head); /*调用遍历链表并打印食品类商品函数*/ break; void tongji1 p1=head; printf("n*n"); printf("库存量低于100的货名及类别n"); printf("*n"); printf("_n"); printf("商品名称t商品类型n"); printf("_n"); while(p1!=NULL) /*判断遍历链表循环结束条件*/ if(p1->quantity<100) /*判断库存量是否小于100*/ printf("%st%sn",p1->name,p1->kind); /*输出商品名称及类别*/ printf("_n"); p1=p1->next; void tongji2 printf("n*n"); printf("商品库存量有2种以上低于100的商品类别:n"); printf("*n"); printf("_n"); if(a0<100)&&(a0>=2) /*判断电器类库存量是否为2种以上低于100*/ printf("电器n"); printf("_n"); if(a1<100)&&(a1>=2) /*判断日用品类库存量是否为2种以上低于100*/ printf("日用品n"); printf("_n"); if(a2<100)&&(a2>=2) /*判断食品类库存量是否为2种以上低于100*/ printf("食品n"); printf("_n"); if(a3<100)&&(a3>=2) /*判断办公用品类库存量是否为2种以上低于100*/ printf("办公用品n"); printf("_n"); int main(int argc, char* argv) struct good *p1,*p2; /*定义结构体指针类型*/

    注意事项

    本文(C语言超市管理系统源程序.docx)为本站会员(牧羊曲112)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开