C语言程序设计超市管理系统完整可编辑版Word下载.docx

上传人:b****3 文档编号:15357103 上传时间:2022-10-29 格式:DOCX 页数:25 大小:292.77KB
下载 相关 举报
C语言程序设计超市管理系统完整可编辑版Word下载.docx_第1页
第1页 / 共25页
C语言程序设计超市管理系统完整可编辑版Word下载.docx_第2页
第2页 / 共25页
C语言程序设计超市管理系统完整可编辑版Word下载.docx_第3页
第3页 / 共25页
C语言程序设计超市管理系统完整可编辑版Word下载.docx_第4页
第4页 / 共25页
C语言程序设计超市管理系统完整可编辑版Word下载.docx_第5页
第5页 / 共25页
点击查看更多>>
下载资源
资源描述

C语言程序设计超市管理系统完整可编辑版Word下载.docx

《C语言程序设计超市管理系统完整可编辑版Word下载.docx》由会员分享,可在线阅读,更多相关《C语言程序设计超市管理系统完整可编辑版Word下载.docx(25页珍藏版)》请在冰豆网上搜索。

C语言程序设计超市管理系统完整可编辑版Word下载.docx

统计输出有两种以上(含两种)商品库存量低于100的商品类别。

2)概要设计:

系统总体设计框架:

系统功能模块图:

3)详细设计:

主要功能模块的算法设计思路:

本程序主要分为八个模块:

主模块、信息输出修改模块、新建信息模块、排序模块、计算模块、统计模块1、统计模块2、打印模块。

1)主模块:

通过调用各分模块实现功能;

2)信息输出修改模块:

输出显示文件中商品信息内容,添加商品信息,删除商品信息,修改商品信息;

3)新建商品信息模块:

建立一个新结构体,为链表存信息用,并且将信息保存在指定的文件中;

4)排序模块:

把文件中顺序零乱的商品信息按单价的大小从高到低进行排序,放到链表里存储;

5)计算模块:

将所有商品的价格与库存量进行累加求和;

6)打印模块:

将商品信息按每类平均价格排序(从高到低)按顺序打印出来;

7)统计模块1:

统计库存量低于100的货名及类别;

8)统计模块2:

统计商品库存量有2种以上(含2种)低于100的商品类别

工作流程图:

4)主要源程序代码:

#include"

stdio.h"

/*输入,输出头文件*/

stdlib.h"

/*申请空间头文件*/

string.h"

/*对字符串加工头文件*/

conio.h"

/*清屏头文件*/

FILE*fp;

intn=0;

/*定义文件指针类型*/

inti,j,a[4],m;

/*定义整数类型*/

floataver[4],sum[4],g[4],h;

/*定义浮点类型*/

charc[5]="

elec"

;

/*定义字符数组类型*/

chard[5]="

comm"

chare[5]="

food"

charf[5]="

offi"

structgood/*定义结构体*/

{

intnum;

/*商品编号*/

charname[20];

/*商品名称*/

charkind[40];

/*商品类型*/

floatprice;

/*商品价格*/

charunit[10];

/*商品单位*/

intquantity;

/*商品数量*/

structgood*next;

/*定义结构体指针类型*/

}*head,*p1,*p2;

structgood*createlist()/*创建链表函数*/

structgood*head1,*p1,*p2;

if((fp=fopen("

goodsmessage.txt"

"

w"

))==NULL)/*判断能否打开文件*/

{

printf("

cannotopenthefile"

);

exit(0);

/*结束程序*/

}

head1=(structgood*)malloc(sizeof(structgood));

/*申请头结点空间*/

p1=head1;

p2=head1;

*********************************************\n"

请输入信息:

编号,名称,类型,价格,单位,数目\n"

(以输入“-1”表示结束输入)\n"

____________________\n"

scanf("

%d%s%s%f%s%d"

&

p1->

num,p1->

name,p1->

kind,&

price,p1->

unit,&

quantity);

/*输入商品信息*/

p1->

next=NULL;

fprintf(fp,"

%d%s%s%f%s%d"

p1->

kind,p1->

unit,p1->

/*将商品信息写入文件*/

while

(1)

p1=(structgood*)malloc(sizeof(structgood));

/*申请新空间*/

%d"

num);

if(p1->

num==-1)/*申请空间结束条件*/

____________________\n\n"

-1);

fclose(fp);

returnhead1;

/*返回头指针*/

%s%s%f%s%d"

/*输入商品信息*/

________________\n"

p2->

next=p1;

p2=p1;

}

structgood*paixu(structgood*head2)/*链表排序函数*/

structgood*p6,*p7,*r,*s;

for(i=0;

i<

=3;

i++)/*赋初值值*/

a[i]=0;

sum[i]=0;

aver[i]=0;

p6=(structgood*)malloc(sizeof(structgood));

p6->

next=head2;

head2=p6;

while(p6->

next!

=NULL)/*判断循环结束条件*/

p7=p6->

next;

r=p6;

while(p7->

if((p7->

next->

price)>

(r->

price))/*判断是否调换*/

r=p7;

p7=p7->

if(p6!

=r)/*判断循环结束条件*/

s=r->

/*指针调换*/

r->

next=s->

s->

next=p6->

next=s;

p6=p6->

p6=head2;

head2=head2->

free(p6);

/*释放第一个无效空间*/

returnhead2;

voidjisuan()

p1=head;

do

if(strcmp(p1->

kind,c)==0)/*判断是否为电器类型*/

sum[0]=sum[0]+(p1->

price)*(p1->

/*求电器总价*/

a[0]=a[0]+p1->

quantity;

/*求电器总件数*/

kind,d)==0)/*判断是否为日用品类型*/

sum[1]=sum[1]+(p1->

/*求日用品总价*/

a[1]=a[1]+p1->

/*求日用品总件数*/

kind,e)==0)/*判断是否为办公用品类型*/

sum[2]=sum[2]+(p1->

/*求办公用品总价*/

a[2]=a[2]+p1->

/*求办公用品总件数*/

kind,f)==0)/*判断是否为食品类型*/

sum[3]=sum[3]+(p1->

/*求食品总价*/

a[3]=a[3]+p1->

/*求食品总件数*/

p1=p1->

}while(p1!

=NULL);

/*遍历链表结束条件*/

4;

i++)

aver[i]=sum[i]/a[i];

/*求每类商品平均价*/

****************************************************\n"

商品类型\t平均价\t总库存量\n"

____________________________________________________\n"

电器总价值:

%0.1f\t平均价:

%0.1f\t总库存量:

%d\n"

sum[0],aver[0],a[0]);

日用品总价值:

sum[1],aver[1],a[1]);

食品总价值:

sum[2],aver[2],a[2]);

办公用品总价值:

sum[3],

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 经管营销 > 经济市场

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

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