超市管理系统java代码,超市管理系统完整+源代码
《超市管理系统完整+源代码》由会员分享,可在线阅读,更多相关《超市管理系统完整+源代码(21页珍藏版)》请在⼈⼈⽂库⽹上搜索。
1、有⼀个⼩型超市,出售N(N10)种商品,设计并实现⼀个系统,完成下列功能:1 保存及输出。超市中的各种商品信息保存在指定⽂件中,可以把它们输出显⽰。2 计算并排序。计算每类商品的总价值(sum,单精度)及平均价(aver,单精度,输出⼀位⼩数),将每类商品按平均价从⼤到⼩的顺序排序打印出来。3 统计。统计输出库存量低于100的货号及类别。统计输出有两种以上(含两种)商品库存量低于100的商品类别。1.2总体结构本程序主要分为⼋个模块:主模块、信息输出修改模块、新建信息模块、排序模块、计算模块、统计模块1、统计模块
2、打印模块。1) 主模块:通过调⽤各分模块实现功能;2) 信息输出修改模块:输出。
2、显⽰⽂件中商品信息内容,添加商品信息,删除商品信息,修改商品信息;3) 新建商品信息模块:建⽴⼀个新结构体,为链表存信息⽤,并且将信息保存在指定的⽂件中;4) 排序模块:把⽂件中顺序零乱的商品信息按单价的⼤⼩从⾼到低进⾏排序,放到链表⾥存储;5)计算模块:将所有商品的价格与库存量进⾏累加求和;6) 打印模块:将商品信息按每类平均价格排序(从⾼到低)按顺序打印出来;7) 统计模块1:统计库存量低于100的货名及类别;8) 统计模块2:统计商品库存量有2种以上(含2种)低于100的
商品类别。附 录(程序清
单)#include stdio.h /*输⼊,输出头⽂件*/ #include stdli。
3、b.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; /*。
4、商品编号*/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(,w)=NULL) /*判断能否打开⽂件*/printf(can not。
5、 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 %s %s %f %s %d,&p1-num,p1-name,p1-kind,&p1-price,p1-unit,&p1-quantity。
6、); /*输⼊商品信息*/ 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( (以输⼊“1”表⽰结束输⼊)n);printf(*n);pri。
7、ntf(____________________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-。
8、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) /*判断循环结束条件*/if(p7-next-pr。
9、ice)(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;doif(strcmp(p1-kind,c)=0) /*判断是否为电器类型*/ sum0=sum0+(p1-price)*(p1-quantity); /*求。
10、电器总价*/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) /*判断是。
11、否为⾷品类型*/ sum3=sum3+(p1-price)*(p1-quantity); /*求⾷品总价*/a3=a3+p1-quantity; /*求⾷
品总件数*/ p1=p1-
next;while (p1!=NULL); /*遍历链表结束条件*/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!=。
12、-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;elsep3-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(______。
13、____________________________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 返回(当你完成了对某⼀商品的添加、删除或者修改后请按4返
回)n);printf(*n); scanf(%d,&n);if(n=1) /*添加商品信息*/ printf(请输⼊商品 编号 名称 类型 价格 单位 数⽬n);printf(*n); p4=(struct good。
14、 *)malloc(sizeof(struct good); /*申请空间*/scanf(%d %s %s %f %s %d,&p4-num,p4-name,p4-kin
d,&p4-price,p4-
unit,&p4-quantity); /*输⼊商品信息*/ p4-next=NULL;while(p3-next!=NULL) /*判断循环结束条件*/p3=p3-next;p3-
next=p4;p3=head;if(fp=fopen(,w)=NULL) /*判断能否打开⽂件*/printf(can not open the file);exit(0); /*结。
网站源码在线15、束程序*/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); /*关闭⽂件*/printf(*n);
printf(__________________________________n);printf(-请按4返回-n);printf(__________________________________n);printf(*n);
if(n=2。
16、) /*删除商品*/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); /*释放空间*/elsep4=head;p3=p4-
next;while(p3!=NULL) /*判断循环结束条件*/if(p3-num)=p)p5=p3-next;free(p3); /*释放空间*/p4-next=p5;break;p3=p3-。
17、next;p4=p4-next;if(fp=fopen(,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。
18、=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)。
19、;scanf(%f %d,&p3-price,&p3-quantity); /*输⼊商品价格与库存量*/ p3=p3-next;if(fp=fopen(,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。
20、-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; /*跳出循环*/。
21、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-unit,p3-quantity); /*输出电器类商品信息
*/printf(_________。
22、_______________________________________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)。
23、; /*输出⽇⽤品类商品信息*/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-k。
24、ind,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%。
25、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;iquantityname,p1-kind); /*输出商品名称及类别*/printf(________________________n);p1=p1-next;void tongji2()printf(n*n);printf(商品库存。
26、量有2种以上(含2种)低于100的商品类别:n);printf(*n);printf(________n);if(a0=2) /*判断电器类库存量是否为2种以上(含2种)低于100*/printf(电器n);printf(________n);if(a1=2) /*判断⽇⽤品类库存量是否为2种以上(含2种)低于100*/printf(⽇⽤品
n);printf(________n);if(a2=2) /*判断⾷品类库存量是否为2种以上(含2种)低于100*/printf(⾷品n);printf(________n);if(a3=2) /*判断办公⽤品类库存量是否为2种以上(含2种)低于100*/。
27、printf(办公⽤品n);printf(________n);int main(int argc, char* argv)struct good *p1,*p2; /*定义结构体指针类型*/
while(1)printf(*n);printf(1 -输出查看或者修改已存信息-n);printf(-n);printf(2 -重新输⼊新信息(并且删除原有信息)-n);printf(-
n);printf(3 统计商品信息(如果您还没有查看过信息请先按1)n); printf(-n);printf(4 -退出-
n);printf(*n);scanf(%d,&m);if(m=1)shuchu(); /。
28、*调⽤输出信息函数*/if(m=2)system(cls);head=createlist(); /*调⽤建⽴链表函数*/ if(m=3)printf(统计结果如下n);
head=paixu(head); /*调⽤链表排序函数*/ jisuan(); /*调⽤计算函数*/ shunxudayin(); /*调⽤顺序打印函数*/ tongji1(); /*调⽤统计1函数*/ tongji2(); /*调⽤统计2函数*/ if(m=4)p1=head;while(p1!=NULL) /*判断遍历链表结束条件*/p2=p1-next;free(p1); /*释放空间*/p1=p2;break;return 0; /*结束程序*/。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论