C语言程序设计超市的管理系统docWord下载.docx

上传人:b****5 文档编号:17436143 上传时间:2022-12-01 格式:DOCX 页数:37 大小:21.54KB
下载 相关 举报
C语言程序设计超市的管理系统docWord下载.docx_第1页
第1页 / 共37页
C语言程序设计超市的管理系统docWord下载.docx_第2页
第2页 / 共37页
C语言程序设计超市的管理系统docWord下载.docx_第3页
第3页 / 共37页
C语言程序设计超市的管理系统docWord下载.docx_第4页
第4页 / 共37页
C语言程序设计超市的管理系统docWord下载.docx_第5页
第5页 / 共37页
点击查看更多>>
下载资源
资源描述

C语言程序设计超市的管理系统docWord下载.docx

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

C语言程序设计超市的管理系统docWord下载.docx

1

2

系统功能模块图:

主模块

信息输出新建信息排序模块统计模块统计模块打印模块

添加商品信息输出主模块商品价格(从计算模块商品信息

高到低)

删除某商品平均价

信息

修改某商品

3)详细设计:

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

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

主模块、信息输出修

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

1)主模块:

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

2)信息输出修改模块:

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

3)新建商品信息模块:

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

4)排序模块:

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

5)计算模块:

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

6)打印模块:

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

7)统计模块1:

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

8)统计模块2:

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

工作流程图:

开始

输出商品信

新建商品信

统计商品信

退出

息或修改商

息(删除原有

品信息

信息)

添加商品信删除某商品修改某商品

息信息信息

输入商品信息(编

号、名称、类型、

价格、单位、数目)

输出(商品类排序(按价格

型、平均价、从高到低)

总库存量)

确认或取消返回输入商品单结束输入

价和库存量

4)主要源程序代码:

#include"

"

/*

输入,输出头文件*/

申请空间头文件*/

对字符串加工头文件*/

清屏头文件*/

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("

goods"

"

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->

u

nit,&

quantity);

/*输入商品信息*/printf("

next=NULL;

fprintf(fp,"

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

p1->

kind,p1->

unit,p1->

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

while

(1)

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

申请新空

间*/

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

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

%d"

num);

if(p1->

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

\n"

____________________\n\n"

-1);

fclose(fp);

returnhead1;

/*返回头指针*/

%s%s%f%s%d"

unit,&

quantity);

/*输入商品信息*/

________________\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"

电器总价值:

%\t平均价:

%\t总库存

量:

%d\n"

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

日用品总价值:

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

食品总价值:

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

办公用品总价值:

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

voidshuchu()/*输出商品信息函数*/

structgood*p3,*p4,*p5;

/*定义结构体指针类型*/intn=0,p=0,q=0,r=0;

所有商品信息:

\n"

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

rb+"

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

/*申请头结点空间*/

p3=head;

fscanf(fp,"

p3->

num,p3->

name,p3->

price,p3->

/*从文件中写到链表*/

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

%d"

p4->

if(p4->

num!

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

%s%s%f%s%d

p4->

name,p4->

price,p4->

/*从文件中写

到链表*/

next=p4;

p3=p4;

else

break;

关闭文件

while(p3!

=NULL)

%d%s%s%%s%d\n\n"

p3->

kind,p3->

unit,p3->

__________________________________\n"

p3=p3->

//////////////////////////////////\n"

while(n!

=4)

3

4

添加商品信息\n"

删除某商品信息\n"

修改某商品信息\n"

返回(当你完成了对某一商品的添加、删除或者修改后请按

4返

回)\n"

n);

if(n==1)/*添加商品信息*/

请输入商品编号名称类型

价格

单位

数目\n"

申请空间*/

num,p4->

while(p3->

=NULL)/*

输入商品信息*/

判断循环结束条件

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

件*/

结束程序*/

kind,p3->

quantity);

/*关闭文件*/

------------请按4返回-------------\n"

if(n==2)/*删除商品*/

请输入需要删除的商品编号\n"

p);

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

1确认删除\n2取消删除\n"

r);

if(r==1)

if((head->

num)==p)

head=head->

free(p3);

p4=head;

p3=p4->

if((p3->

p5=p3->

释放空间*/

next=p5;

p4=p4->

if(r==2)

continue;

/*继续循环*/

if(n==3)/*修改某商品信息*/

请输入需要修改的商品编号\n"

q);

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

num)==q)/*判断是否为所需要修改的商品

请输入商品单价与库存量(如果单价不变请输入原来的单价)

%f%d"

price,&

价格与库存量*/

输入商品

))==NULL)

判断能否打开文

%d%s%s%f

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

当前位置:首页 > PPT模板 > 卡通动漫

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

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