针对包含c语言超市管理员系统的词条的内容, 嗨壳技术分享网今天给大家作出详细的解答吧!
今天给各位分享c语言超市管理员系统的知识,其中也会对进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!
本文目录一览:
1、C语言程序设计 超市商品信息管理系统
2、c语言 超市管理系统
3、求一个简单的C语言超市收银系统
4、用c语言实现超市商品管理系统,用指针实现商品的插入、删除操作。
5、用c语言设计一个超市管理系统程序,要求能添加商品,能查询商品,能购买商品,能展示商品。
6、C语言编写的超市管理系统
C语言程序设计 超市商品信息管理系统
假设某超市经营各种商品,每种商品包括以下信息:商品编号、商品名称、商品品牌、库存数量、售价、已售数量。系统的主要功能包括:1. 创建商品信息文件:根据提示输入若干商品的信息,并将信息保存至一个文件中。2. 商品进货管理:每次购入新商品,需按要求输入商品所含各项信息并存入商品信息文件中。如果已经存在该商品(以商品编号为准),则修改相应的库存数量信息,否则生成新的商品信息记录。3. 商品销售管理:每次有商品销售出去,则按要求输入商品编号和商品名称信息,并修改相应的商品信息文件。注意:商品销售时要检查库存数量的合法性(即销售出去的数量必须小于库存数量)。4. 按不同条件进行查询操作,输出满足条件的商品信息。(1) 输入商品名称,在商品信息文件中查找相应的商品信息并输出。(2) 输入商品品牌,在商品信息文件中查找该品牌的所有信息并输出。5. 按不同条件对商品信息进行统计工作。(1) 输入商品名称,在商品信息文件中统计该商品的销售总额。(2) 设置一个库存数量警戒值,输出库存数量小于该警戒值的所有库存商品的信息。(3) 输入商品品牌,在商品信息文件中统计其不同商品名称的库存量,并输出库存量最高的那个商品的信息。
c语言 超市管理系统
有一个小型超市,出售N(N=10)种商品,设计并实现一个系统,完成下列功能:
1. 保存及输出。超市中的各种商品信息保存在指定文件中,可以把它们输出显示。
2. 计算并排序。计算每类商品的总价值(sum,单精度)及平均价(aver,单精度,输出一位小数),将每类商品按平均价从大到小的顺序排序打印出来。
3. 统计。统计输出库存量低于100的货号及类别。统计输出有两种以上(含两种)商品库存量低于100的商品类别。
1.2总体结构
本程序主要分为八个模块:主模块、信息输出修改模块、新建信息模块、排序模块、计算模块、统计模块1、统计模块2、打印模块。
1) 主模块:通过调用各分模块实现功能;
2) 信息输出修改模块:输出显示文件中商品信息内容,添加商品信息,删除商品信息,修改商品信息;
3) 新建商品信息模块:建立一个新结构体,为链表存信息用,并且将信息保存在指定的文件中;
4) 排序模块:把文件中顺序零乱的商品信息按单价的大小从高到低进行排序,放到链表里存储;
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; /*定义文件指针类型*/
int i,j,a[4],m; /*定义整数类型*/
float aver[4],sum[4],g[4],h; /*定义浮点类型*/
char c[5]=”elec”; /*定义字符数组类型*/
char d[5]=”comm”; /*定义字符数组类型*/
char e[5]=”food”; /*定义字符数组类型*/
char f[5]=”offi”; /*定义字符数组类型*/
struct good /*定义结构体*/
{
int num; /*商品编号*/
char name[20]; /*商品名称*/
char kind[40]; /*商品类型*/
float price; /*商品价格*/
char unit[10]; /*商品单位*/
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(“*********************************************
”);
printf(“请输入信息:编号,名称,类型,价格,单位,数目
”);
printf(” (以输入“-1”表示结束输入)
”);
printf(“*********************************************
”);
printf(“____________________
”);
scanf(“%d %s %s %f %s %d”,p1-num,p1-name,p1-kind,p1-price,p1-unit,p1-quantity); /*输入商品信息*/
printf(“____________________
”);
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(“*********************************************
”);
printf(“请输入信息:编号,名称,类型,价格,单位,数目
”);
printf(” (以输入“-1”表示结束输入)
”);
printf(“*********************************************
”);
printf(“____________________
”);
scanf(“%d”,p1-num);
if(p1-num==-1) /*申请空间结束条件*/
{
printf(“____________________
”);
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(“________________
”);
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++) /*赋初值值*/
{
a[i]=0;
sum[i]=0;
aver[i]=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) /*判断是否为电器类型*/
{
sum[0]=sum[0]+(p1-price)*(p1-quantity); /*求电器总价*/
a[0]=a[0]+p1-quantity; /*求电器总件数*/
}
if(strcmp(p1-kind,d)==0) /*判断是否为日用品类型*/
{
sum[1]=sum[1]+(p1-price)*(p1-quantity); /*求日用品总价*/
a[1]=a[1]+p1-quantity; /*求日用品总件数*/
}
if(strcmp(p1-kind,e)==0) /*判断是否为办公用品类型*/
{
sum[2]=sum[2]+(p1-price)*(p1-quantity); /*求办公用品总价*/
a[2]=a[2]+p1-quantity; /*求办公用品总件数*/
}
if(strcmp(p1-kind,f)==0) /*判断是否为食品类型*/
{
sum[3]=sum[3]+(p1-price)*(p1-quantity); /*求食品总价*/
a[3]=a[3]+p1-quantity; /*求食品总件数*/
}
p1=p1-next;
}while (p1!=NULL); /*遍历链表结束条件*/
for(i=0;i4;i++)
aver[i]=sum[i]/a[i]; /*求每类商品平均价*/
printf(“****************************************************
”);
printf(“商品类型 平均价 总库存量
”);
printf(“****************************************************
”);
printf(“____________________________________________________
”);
printf(“电器总价值:%0.1f 平均价:%0.1f 总库存量:%d
”,sum[0],aver[0],a[0]);
printf(“____________________________________________________
”);
printf(“日用品总价值:%0.1f 平均价:%0.1f 总库存量:%d
”,sum[1],aver[1],a[1]);
printf(“____________________________________________________
”);
printf(“食品总价值:%0.1f 平均价:%0.1f 总库存量:%d
”,sum[2],aver[2],a[2]);
printf(“____________________________________________________
”);
printf(“办公用品总价值:%0.1f 平均价:%0.1f 总库存量:%d
”,sum[3],aver[3],a[3]);
printf(“____________________________________________________
”);
}
void shuchu() /*输出商品信息函数*/
{
do
{
struct good *p3,*p4,*p5; /*定义结构体指针类型*/
int n=0,p=0,q=0,r=0;
printf(“所有商品信息:
”);
printf(“编号,名称,类型,价格,单位,数目
”);
printf(“**********************************
”);
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 %d
”,p3-num,p3-name,p3-kind,p3-price,p3-unit,p3-quantity);
printf(“__________________________________
”);
p3=p3-next;
}
printf(“**********************************
”);
printf(“https://////////////////////////////////
”);
while(n!=4)
{
p3=head;
printf(“**********************************
”);
printf(“1 添加商品信息
”);
printf(“2 删除某商品信息
”);
printf(“3 修改某商品信息
”);
printf(“4 返回(当你完成了对某一商品的添加、删除或者修改后请按4返回)
”);
printf(“**********************************
”);
scanf(“%d”,n);
if(n==1) /*添加商品信息*/
{
printf(“请输入商品 编号 名称 类型 价格 单位 数目
”);
printf(“**********************************
”);
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 %s %d “,p3-num,p3-name,p3-kind,p3-price,p3-unit,p3-quantity) /*将商品信息写入文件*/
p3=p3-next;
}
fprintf(fp,”%d”,-1);
fclose(fp); /*关闭文件*/
printf(“**********************************
”);
printf(“__________________________________
”);
printf(“————请按4返回————-
”);
printf(“__________________________________
”);
printf(“**********************************
”);
}
if(n==2) /*删除商品*/
{
printf(“**********************************
”);
printf(“请输入需要删除的商品编号
”);
printf(“**********************************
”);
scanf(“%d”,p);
printf(“**********
”);
printf(“1 确认删除
2 取消删除
”);
printf(“**********
”);
scanf(“%d”,r);
if(r==1)
{
if((head-num)==p)
{
head=head-next;
free(p3); /*释放空间*/
}
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,”%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(“**********************************
”);
printf(“__________________________________
”);
printf(“————请按4返回————-
”);
printf(“__________________________________
”);
printf(“**********************************
”);
}
if(n==3) /*修改某商品信息*/
{
printf(“请输入需要修改的商品编号
”);
scanf(“%d”,q);
while(p3!=NULL) /*判断循环结束条件*/
{
if((p3-num)==q) /*判断是否为所需要修改的商品*/
{
printf(“请输入商品单价与库存量(如果单价不变请输入原来的单价)
”);
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 %s %d “,p3-num,p3-name,p3-kind,p3-price,p3-unit,p3-quantity); /*将商品信息写入文件*/
p3=p3-next;
}
fprintf(fp,”%d”,-1);
fclose(fp); /*关闭文件*/
printf(“**********************************
”);
printf(“__________________________________
”);
printf(“————请按4返回————-
”);
printf(“__________________________________
”);
printf(“**********************************
”);
}
if(n==4) /*退出*/
break;
}
printf(“**********
”);
printf(“1 继续修改
———
2 返回
”);
printf(“**********
”);
scanf(“%d”,p);
if(p==1)
continue; /*继续循环*/
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(“%d %s %s %0.1f %s %d
”,p3-num,p3-name,p3-kind,p3-price,p3-unit,p3-quantity); /*输出电器类商品信息*/
printf(“________________________________________________
”);
}
p3=p3-next;
}
return;
}
void printf1(struct good *p) /*遍历链表并打印日用品类商品函数*/
{
struct good *p3; /*定义结构体指针类型*/
p3=p;
while (p3!=NULL) /*判断遍历链表循环结束条件*/
{
if(strcmp(p3-kind,d)==0) /*判断商品类型是否为日用品类型*/
{
printf(“%d %s %s %0.1f %s %d
”,p3-num,p3-name,p3-kind,p3-price,p3-unit,p3-quantity); /*输出日用品类商品信息*/
printf(“________________________________________________
”);
}
p3=p3-next;
}
return;
}
void printf2(struct good *p) /*遍历链表并打印办公用品类商品函数*/
{
struct good *p3; /*定义结构体指针类型*/
p3=p;
while (p3!=NULL) /*判断遍历链表循环结束条件*/
{
if(strcmp(p3-kind,e)==0) /*判断商品类型是否为办公用品类型*/
{
printf(“%d %s %s %0.1f %s %d
”,p3-num,p3-name,p3-kind,p3-price,p3-unit,p3-quantity); /*输出办公用品类商品信息*/
printf(“________________________________________________
”);
}
p3=p3-next;
}
return;
}
void printf3(struct good *p) /*遍历链表并打印食品类商品函数*/
{
struct good *p3; /*定义结构体指针类型*/
p3=p;
while (p3!=NULL) /*判断遍历链表循环结束条件*/
{
if(strcmp(p3-kind,f)==0) /*判断商品类型是否为食品类型*/
{
printf(“%d %s %s %0.1f %s %d
”,p3-num,p3-name,p3-kind,p3-price,p3-unit,p3-quantity); /*输出食品类商品信息*/
printf(“________________________________________________
”);
}
p3=p3-next;
}
return;
}
void shunxudayin()
{
for(i=0;i4;i++)
g[i]=aver[i]; /*将平均价赋给新数组*/
for(j=0;j3;j++) /*将新数组用冒泡排序法排序*/
for(i=j+1;i4;i++)
{
if(g[j]g[i])
{
h=g[j];
g[j]=g[i];
g[i]=h;
}
}
printf(“
****************************
”);
printf(“商品平均价格排序表(从高到低)
”);
printf(“****************************
”);
printf(“________________________________________________
”);
printf(“编号 名称 类别 单价 单位 数量
”);
printf(“________________________________________________
”);
for(j=0;j4;j++)
for(i=0;i4;i++)
{
if (aver[i]==g[j]) /*判断每类商品平均价格的先后顺序*/
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(“
************************
”);
printf(“库存量低于100的货名及类别
”);
printf(“************************
”);
printf(“________________________
”);
printf(“商品名称 商品类型
”);
printf(“________________________
”);
while(p1!=NULL) /*判断遍历链表循环结束条件*/
{
if(p1-quantity100) /*判断库存量是否小于100*/
{
printf(“%s %s
”,p1-name,p1-kind); /*输出商品名称及类别*/
printf(“________________________
”);
}
p1=p1-next;
}
}
void tongji2()
{
printf(“
**********************************************
”);
printf(“商品库存量有2种以上(含2种)低于100的商品类别:
”);
printf(“**********************************************
”);
printf(“________
”);
if((a[0]100)(a[0]=2)) /*判断电器类库存量是否为2种以上(含2种)低于100*/
{
printf(“电器
”);
printf(“________
”);
}
if((a[1]100)(a[1]=2)) /*判断日用品类库存量是否为2种以上(含2种)低于100*/
{
printf(“日用品
”);
printf(“________
”);
}
if((a[2]100)(a[2]=2)) /*判断食品类库存量是否为2种以上(含2种)低于100*/
{
printf(“食品
”);
printf(“________
”);
}
if((a[3]100)(a[3]=2)) /*判断办公用品类库存量是否为2种以上(含2种)低于100*/
{
printf(“办公用品
”);
printf(“________
”);
}
}
int main(int argc, char* argv[])
{
struct good *p1,*p2; /*定义结构体指针类型*/
while(1)
{
printf(“***********************************************
”);
printf(“1 ———-输出查看或者修改已存信息———–
”);
printf(“———————————————–
”);
printf(“2 —–重新输入新信息(并且删除原有信息)——
”);
printf(“———————————————–
”);
printf(“3 统计商品信息(如果您还没有查看过信息请先按1)
”);
printf(“———————————————–
”);
printf(“4 ——————-退出———————
”);
printf(“***********************************************
”);
scanf(“%d”,m);
if(m==1)
shuchu(); /*调用输出信息函数*/
if(m==2)
{
system(“cls”);
head=createlist(); /*调用建立链表函数*/
}
if(m==3)
{
printf(“统计结果如下
”);
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; /*结束程序*/
}
请采纳答案,支持我一下。
求一个简单的C语言超市收银系统
这里没有商品信息,需要自己编码添加。
#include stdio.h
#include string.h
typedef struct ln //会员信息
{
char id[20];//会员账号
char key[20];//会员密码
int sum;//会员积分
struct ln *next;
} member;
struct lm//商品信息
{
int id;//商品编号
char name[50];//商品名称
int stock;//商品库存
} goods[1000];
member *registe(member *t);//注册;
void buy();
int main()
{
member *head=(member *)malloc(sizeof(member));
strcpy(head-id, “0”), strcpy(head-key, “0”);//超市管理员
head-next=NULL;
int i, a, n, boo=0;
while(1)
{
printf(” 注册会员请按1:
”);
printf(” 会员直接登录请按2:
”);
printf(” 退出请按0:
”);
scanf(“%d”, a);
if(a==0) break;
if(a==1) head=registe(head);
else if(a==2) boo=login(head);
if(boo) break;
}
if(a boo==1)
{
printf(” 尊贵的会员,您登录成功!
”);
buy();
}
printf(” 已经安全退出
”);
}
member *registe(member *t)//注册
{
printf(” 现在开始会员注册
”);
char id[20], key[20];
member *p, *q, *r;
p=t;
while(p-next) p=p-next;//寻找链表中最后一个结点
while(1)
{
printf(” 请输入您注册的账号,密码:
”);
scanf(“%s %s”, id, key);
q=t;
while(q)//判断该账号是否已经被注册
{
if(strcmp(q-id, id)==0) break;
else q=q-next;
}
用c语言实现超市商品管理系统,用指针实现商品的插入、删除操作。
可以用链表,大致就是,你创建一个结构体,结构体里有商品的一些信息,然后关键的是有个该结构体的指针,这个指针是指向下一个商品的结构体地址的,依次类推,直到最后一个商品的指针是指向null的,然后开始插入商品的思路:①创建新商品的信息②先让你要插入的结构体的指针指向要插入的那个位置后边的地址,③然后插入位置的前面的结构体指向要插入商品④如果是插在末尾,或者开头,你就注意是谁指向谁的问题。删除商品思路:直接修改要删除的商品之前的指针,绕过要删除的商品,指向下一个不擅长的商品就ok。
struct book
{
long book_number; //记录书的编号
char book_name[N]; //储存书的名字
double book_price; //记录书的价格
char book_author[N];//记录书的作者
char book_state[N]; //记录书的借还状态
int book_num; //记录书的数量
char borrower_name[N];//记录借书人姓名
char borrower_sex[M];//记录借书人性别
long borrower_number; //记录借书人学号
struct book *book_next;//指向下一个结构体
};//以前写的图书管理系统作为链表元素的结构体,只要关注最后一个指针就好了
BOOK *DelBook(BOOK *book_head) /* 此函数负责删除图书 *//*思路为连续读取文件内容,找到要删除的文件内容的位置,写入一份新的文件,再替换掉旧文件*/
{
long num;//记录书籍号
int flag = 0;//控制开关
char ch;//记录用户的选择
BOOK *p = book_head;
BOOK *pr = NULL;
printf(“
功能:删除一本图书的所有信息
”);
printf(“输入你要删除的书籍号”);
scanf(“%ld”,num);
read_book_file(book_head);//将图书信息写入节点
while(num != p-book_number p-book_next != NULL)//查找节点并显示节点内容并且记录节点的地址
{
pr = p;
p = p-book_next;
}
if (book_head == NULL)/*数据不能正常获取*/
{
exit(0);
}
else if(num = p-book_num) /*找到了对应的*/
{
PrintBook(p);
printf(“你确定要删除么?”);
scanf(” %c”,ch);
if (ch == ‘y’||ch == ‘Y’)
{
while(!flag)
{
if (book_head == NULL)
{
printf(“链表为空
”);
return book_head;
}
if (p == book_head)//如果是头节点要删除
{
book_head = p-book_next;
free(p);//释放删除节点
flag = 1;
}
else if (p-book_next == NULL)//如果是末节点
{
free(p);//释放删除的节点
p= pr; //改变p的指向
p-book_next == NULL;
flag = 1;
}
else
{
pr-book_next = p-book_next;//删除中间节点
free(p);//释放删除的节点
flag = 1;
}
/*节点删除结束*//*接下来将新的内容写入文件,之前那些内容被覆盖*/
save_book_file(book_head);//调用文件写入函数重新写入
//这样直接就实现了内容的覆盖,相当于删除文本内容
return book_head;//最后返回头节点
}
}
else/*未找到*/
{
fflush(stdin);
return book_head;
}
}
return book_head;
}
以前写的令一个管理系统的一部分,将就着看吧,插入商品和这个差不多
用c语言设计一个超市管理系统程序,要求能添加商品,能查询商品,能购买商品,能展示商品。
超市管理系统
*/
#includestdio.h
#includestring.h
//欢迎界面//
void welcome();
//功能浏览//
void mainMenu();
//购物结算//
void saleCalc();
//进货管理//
void addGoods();
//修改信息
void updateGoods();
//显示商品//
void showGoods();
//删除商品//
void deleteGoods();
//查询商品//
int searchGoods();
//购买结算
void saleCalc();
//更新库存//
void updateGoodsNum(int number,char name[50]);
//结构体
struct goods
{
char name[50];//商品名称
int num;//商品数量
float price;//商品价格
};
int count;//商品种类数量
goods list[1000];//声明goods的变量数组
char name[50];
void main()//主函数
{
int num;
welcome();
do{
mainMenu();
printf(“请选择功能:”);
scanf(“%d”,num);
switch(num)
{
case 1:
saleCalc();
break;
case 2:
addGoods();
break;
case 3:
updateGoods();
break;
case 4:
showGoods();
break;
case 5:
deleteGoods();
break;
case 0:
break;
}
}while(num!=0);
}
void welcome()//欢迎界面
{
printf(“————————————————————————-
”);
printf(“****************欢迎使用超市管理系统*******************
”);
printf(“————————————————————————-
”);
}
void mainMenu()//功能浏览界面
{
printf(“****1.购物结算****
”);
printf(“****2.进货管理****
”);
printf(“****3.修改商品****
”);
printf(“****4.显示商品****
”);
printf(“****5.删除商品****
”);
printf(“****0.退出系统****
”);
}
//查询信息
int searchGoods()//查询商品信息
{
printf(“请输入您要购买商品的名字:”);
scanf(“%s”,name);
for(int i=0;icount;i++)
{
if(stricmp(name,list[i].name)==0)
{
return 1;
}
else
{
printf(“对不起了,没有找到%c商品
”,name);
return -1;
}
}
}
//购物结算
void saleCalc()//购物结算
{
int number,i,s;
float priceGoods=0,sum=0,money;
char c=’ ‘;
s=searchGoods();
do
{
if(s==-1)
{
s=searchGoods();
}else
{
printf(“该商品b存在”);
for(i=0;icount;i++)
{
if(strcmp(name,list[i].name)==0)
{
priceGoods=list[i].price;
break;
}
}
printf(“请输入您要购买的数量:”);
scanf(“%d”,number);
sum=priceGoods*number;
updateGoodsNum(-number,name);
printf(“是否继续购买(y/n)”);
fflush(stdin);
c=getchar();
}
}while(c==’y’||c==’Y’);
printf(“本次消费总金额为:%.2f”,sum);
printf(“请输入您的实际付款金额:”);
scanf(“%f”,money);
printf(“找零:%.2f
”,money-sum);
}
//进货管理
void addGoods() //商品的录入
{
int i=0;
char c=’ ‘;
do
{
printf(“请输入商品的名称:”);
fflush(stdin);
scanf(“%s”,list[i].name);
printf(“请输入商品的数量:”);
scanf(“%d”,list[i].num);
printf(“请输入商品的单价:”);
scanf(“%f”,list[i].price);
printf(“是否继续(y/n)”);
fflush(stdin);
c=getchar();
}while(c==’Y’||c==’y’);
}
//更新库存
void updateGoodsNum(int number,char name[50])
{
int i;
for(i=0;icount;i++)
{
list[i].num+=number;//list[i].num=list[i].num+number
}
}
//显示货物信息
void showGoods()
{
printf(“商品名称 数量 单价
”);
for(int i=0;icount;i++)
{
printf(“%s %d %.2f
”,list[i].name,list[i].num,list[i].price);
}
}
//修改商品信息
void updateGoods()
{
int i;
printf(“请输入您要修改商品的名字:”);
scanf(“%s”,name);
for(i=0;icount;i++)
{
if(strcmp(name,list[i].name)==0)
{
printf(“请输入新的商品名字:”);
scanf(“%s”,list[i].name);
printf(“请输入您要修改商品的数量:”);
scanf(“%d”,list[i].num);
printf(“请输入您要修改商品的单价:”);
scanf(“%f”,list[i].price);
}
else
{
printf(“对不起,没有找到该商品信息!”);
}
}
}
//删除商品信息
void deleteGoods()
{
int index=-1;
printf(“请输入您要删除的商品名字:”);
scanf(“%s”,name);
for(int i=0;icount;i++)
{
if(strcmp(name,list[i].name)==0)
{
index=i;
}
}if(index==-1)
{
printf(“对不起!没有找到您要删除的商品信息!”);
}
else{
for(int i=index;icount;i++)
{
list[i]=list[i+1];
}
}
}
C语言编写的超市管理系统
有一个小型超市,出售N(N=10)种商品,设计并实现一个系统,完成下列功能:
1. 保存及输出。超市中的各种商品信息保存在指定文件中,可以把它们输出显示。
2. 计算并排序。计算每类商品的总价值(sum,单精度)及平均价(aver,单精度,输出一位小数),将每类商品按平均价从大到小的顺序排序打印出来。
3. 统计。统计输出库存量低于100的货号及类别。统计输出有两种以上(含两种)商品库存量低于100的商品类别。
1.2总体结构
本程序主要分为八个模块:主模块、信息输出修改模块、新建信息模块、排序模块、计算模块、统计模块1、统计模块2、打印模块。
1) 主模块:通过调用各分模块实现功能;
2) 信息输出修改模块:输出显示文件中商品信息内容,添加商品信息,删除商品信息,修改商品信息;
3) 新建商品信息模块:建立一个新结构体,为链表存信息用,并且将信息保存在指定的文件中;
4) 排序模块:把文件中顺序零乱的商品信息按单价的大小从高到低进行排序,放到链表里存储;
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; /*定义文件指针类型*/
int i,j,a[4],m; /*定义整数类型*/
float aver[4],sum[4],g[4],h; /*定义浮点类型*/
char c[5]=”elec”; /*定义字符数组类型*/
char d[5]=”comm”; /*定义字符数组类型*/
char e[5]=”food”; /*定义字符数组类型*/
char f[5]=”offi”; /*定义字符数组类型*/
struct good /*定义结构体*/
{
int num; /*商品编号*/
char name[20]; /*商品名称*/
char kind[40]; /*商品类型*/
float price; /*商品价格*/
char unit[10]; /*商品单位*/
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(“*********************************************
”);
printf(“请输入信息:编号,名称,类型,价格,单位,数目
”);
printf(” (以输入“-1”表示结束输入)
”);
printf(“*********************************************
”);
printf(“____________________
”);
scanf(“%d %s %s %f %s %d”,p1-num,p1-name,p1-kind,p1-price,p1-unit,p1-quantity); /*输入商品信息*/
printf(“____________________
”);
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(“*********************************************
”);
printf(“请输入信息:编号,名称,类型,价格,单位,数目
”);
printf(” (以输入“-1”表示结束输入)
”);
printf(“*********************************************
”);
printf(“____________________
”);
scanf(“%d”,p1-num);
if(p1-num==-1) /*申请空间结束条件*/
{
printf(“____________________
”);
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(“________________
”);
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++) /*赋初值值*/
{
a[i]=0;
sum[i]=0;
aver[i]=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) /*判断是否为电器类型*/
{
sum[0]=sum[0]+(p1-price)*(p1-quantity); /*求电器总价*/
a[0]=a[0]+p1-quantity; /*求电器总件数*/
}
if(strcmp(p1-kind,d)==0) /*判断是否为日用品类型*/
{
sum[1]=sum[1]+(p1-price)*(p1-quantity); /*求日用品总价*/
a[1]=a[1]+p1-quantity; /*求日用品总件数*/
}
if(strcmp(p1-kind,e)==0) /*判断是否为办公用品类型*/
{
sum[2]=sum[2]+(p1-price)*(p1-quantity); /*求办公用品总价*/
a[2]=a[2]+p1-quantity; /*求办公用品总件数*/
}
if(strcmp(p1-kind,f)==0) /*判断是否为食品类型*/
{
sum[3]=sum[3]+(p1-price)*(p1-quantity); /*求食品总价*/
a[3]=a[3]+p1-quantity; /*求食品总件数*/
}
p1=p1-next;
}while (p1!=NULL); /*遍历链表结束条件*/
for(i=0;i4;i++)
aver[i]=sum[i]/a[i]; /*求每类商品平均价*/
printf(“****************************************************
”);
printf(“商品类型 平均价 总库存量
”);
printf(“****************************************************
”);
printf(“____________________________________________________
”);
printf(“电器总价值:%0.1f 平均价:%0.1f 总库存量:%d
”,sum[0],aver[0],a[0]);
printf(“____________________________________________________
”);
printf(“日用品总价值:%0.1f 平均价:%0.1f 总库存量:%d
”,sum[1],aver[1],a[1]);
printf(“____________________________________________________
”);
printf(“食品总价值:%0.1f 平均价:%0.1f 总库存量:%d
”,sum[2],aver[2],a[2]);
printf(“____________________________________________________
”);
printf(“办公用品总价值:%0.1f 平均价:%0.1f 总库存量:%d
”,sum[3],aver[3],a[3]);
printf(“____________________________________________________
”);
}
void shuchu() /*输出商品信息函数*/
{
do
{
struct good *p3,*p4,*p5; /*定义结构体指针类型*/
int n=0,p=0,q=0,r=0;
printf(“所有商品信息:
”);
printf(“编号,名称,类型,价格,单位,数目
”);
printf(“**********************************
”);
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 %d
”,p3-num,p3-name,p3-kind,p3-price,p3-unit,p3-quantity);
printf(“__________________________________
”);
p3=p3-next;
}
printf(“**********************************
”);
printf(“https://////////////////////////////////
”);
while(n!=4)
{
p3=head;
printf(“**********************************
”);
printf(“1 添加商品信息
”);
printf(“2 删除某商品信息
”);
printf(“3 修改某商品信息
”);
printf(“4 返回(当你完成了对某一商品的添加、删除或者修改后请按4返回)
”);
printf(“**********************************
”);
scanf(“%d”,n);
if(n==1) /*添加商品信息*/
{
printf(“请输入商品 编号 名称 类型 价格 单位 数目
”);
printf(“**********************************
”);
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 %s %d “,p3-num,p3-name,p3-kind,p3-price,p3-unit,p3-quantity) /*将商品信息写入文件*/
p3=p3-next;
}
fprintf(fp,”%d”,-1);
fclose(fp); /*关闭文件*/
printf(“**********************************
”);
printf(“__________________________________
”);
printf(“————请按4返回————-
”);
printf(“__________________________________
”);
printf(“**********************************
”);
}
if(n==2) /*删除商品*/
{
printf(“**********************************
”);
printf(“请输入需要删除的商品编号
”);
printf(“**********************************
”);
scanf(“%d”,p);
printf(“**********
”);
printf(“1 确认删除
2 取消删除
”);
printf(“**********
”);
scanf(“%d”,r);
if(r==1)
{
if((head-num)==p)
{
head=head-next;
free(p3); /*释放空间*/
}
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,”%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(“**********************************
”);
printf(“__________________________________
”);
printf(“————请按4返回————-
”);
printf(“__________________________________
”);
printf(“**********************************
”);
}
if(n==3) /*修改某商品信息*/
{
printf(“请输入需要修改的商品编号
”);
scanf(“%d”,q);
while(p3!=NULL) /*判断循环结束条件*/
{
if((p3-num)==q) /*判断是否为所需要修改的商品*/
{
printf(“请输入商品单价与库存量(如果单价不变请输入原来的单价)
”);
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 %s %d “,p3-num,p3-name,p3-kind,p3-price,p3-unit,p3-quantity); /*将商品信息写入文件*/
p3=p3-next;
}
fprintf(fp,”%d”,-1);
fclose(fp); /*关闭文件*/
printf(“**********************************
”);
printf(“__________________________________
”);
printf(“————请按4返回————-
”);
printf(“__________________________________
”);
printf(“**********************************
”);
}
if(n==4) /*退出*/
break;
}
printf(“**********
”);
printf(“1 继续修改
———
2 返回
”);
printf(“**********
”);
scanf(“%d”,p);
if(p==1)
continue; /*继续循环*/
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(“%d %s %s %0.1f %s %d
”,p3-num,p3-name,p3-kind,p3-price,p3-unit,p3-quantity); /*输出电器类商品信息*/
printf(“________________________________________________
”);
}
p3=p3-next;
}
return;
}
void printf1(struct good *p) /*遍历链表并打印日用品类商品函数*/
{
struct good *p3; /*定义结构体指针类型*/
p3=p;
while (p3!=NULL) /*判断遍历链表循环结束条件*/
{
if(strcmp(p3-kind,d)==0) /*判断商品类型是否为日用品类型*/
{
printf(“%d %s %s %0.1f %s %d
”,p3-num,p3-name,p3-kind,p3-price,p3-unit,p3-quantity); /*输出日用品类商品信息*/
printf(“________________________________________________
”);
}
p3=p3-next;
}
return;
}
void printf2(struct good *p) /*遍历链表并打印办公用品类商品函数*/
{
struct good *p3; /*定义结构体指针类型*/
p3=p;
while (p3!=NULL) /*判断遍历链表循环结束条件*/
{
if(strcmp(p3-kind,e)==0) /*判断商品类型是否为办公用品类型*/
{
printf(“%d %s %s %0.1f %s %d
”,p3-num,p3-name,p3-kind,p3-price,p3-unit,p3-quantity); /*输出办公用品类商品信息*/
printf(“________________________________________________
”);
}
p3=p3-next;
}
return;
}
void printf3(struct good *p) /*遍历链表并打印食品类商品函数*/
{
struct good *p3; /*定义结构体指针类型*/
p3=p;
while (p3!=NULL) /*判断遍历链表循环结束条件*/
{
if(strcmp(p3-kind,f)==0) /*判断商品类型是否为食品类型*/
{
printf(“%d %s %s %0.1f %s %d
”,p3-num,p3-name,p3-kind,p3-price,p3-unit,p3-quantity); /*输出食品类商品信息*/
printf(“________________________________________________
”);
}
p3=p3-next;
}
return;
}
void shunxudayin()
{
for(i=0;i4;i++)
g[i]=aver[i]; /*将平均价赋给新数组*/
for(j=0;j3;j++) /*将新数组用冒泡排序法排序*/
for(i=j+1;i4;i++)
{
if(g[j]g[i])
{
h=g[j];
g[j]=g[i];
g[i]=h;
}
}
printf(“
****************************
”);
printf(“商品平均价格排序表(从高到低)
”);
printf(“****************************
”);
printf(“________________________________________________
”);
printf(“编号 名称 类别 单价 单位 数量
”);
printf(“________________________________________________
”);
for(j=0;j4;j++)
for(i=0;i4;i++)
{
if (aver[i]==g[j]) /*判断每类商品平均价格的先后顺序*/
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(“
************************
”);
printf(“库存量低于100的货名及类别
”);
printf(“************************
”);
printf(“________________________
”);
printf(“商品名称 商品类型
”);
printf(“________________________
”);
while(p1!=NULL) /*判断遍历链表循环结束条件*/
{
if(p1-quantity100) /*判断库存量是否小于100*/
{
printf(“%s %s
”,p1-name,p1-kind); /*输出商品名称及类别*/
printf(“________________________
”);
}
p1=p1-next;
}
}
void tongji2()
{
printf(“
**********************************************
”);
printf(“商品库存量有2种以上(含2种)低于100的商品类别:
”);
printf(“**********************************************
”);
printf(“________
”);
if((a[0]100)(a[0]=2)) /*判断电器类库存量是否为2种以上(含2种)低于100*/
{
printf(“电器
”);
printf(“________
”);
}
if((a[1]100)(a[1]=2)) /*判断日用品类库存量是否为2种以上(含2种)低于100*/
{
printf(“日用品
”);
printf(“________
”);
}
if((a[2]100)(a[2]=2)) /*判断食品类库存量是否为2种以上(含2种)低于100*/
{
printf(“食品
”);
printf(“________
”);
}
if((a[3]100)(a[3]=2)) /*判断办公用品类库存量是否为2种以上(含2种)低于100*/
{
printf(“办公用品
”);
printf(“________
”);
}
}
int main(int argc, char* argv[])
{
struct good *p1,*p2; /*定义结构体指针类型*/
while(1)
{
printf(“***********************************************
”);
printf(“1 ———-输出查看或者修改已存信息———–
”);
printf(“———————————————–
”);
printf(“2 —–重新输入新信息(并且删除原有信息)——
”);
printf(“———————————————–
”);
printf(“3 统计商品信息(如果您还没有查看过信息请先按1)
”);
printf(“———————————————–
”);
printf(“4 ——————-退出———————
”);
printf(“***********************************************
”);
scanf(“%d”,m);
if(m==1)
shuchu(); /*调用输出信息函数*/
if(m==2)
{
system(“cls”);
head=createlist(); /*调用建立链表函数*/
}
if(m==3)
{
printf(“统计结果如下
”);
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; /*结束程序*/
}
关于c语言超市管理员系统和的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。
对于【 包含c语言超市管理员系统的词条 】文章有相关疑问,还可以参考嗨壳技术分享网,其他技术类文章吧!
原创文章,作者:语言我知,如若转载,请注明出处:https://www.heikehao.com/21923.html