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(“*********************************************\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); /*输入商品信息*/
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”);
printf(“____________________\n”);
scanf(“%d”,p1-num);
if(p1-num==-1) /*申请空间结束条件*/
{
printf(“____________________\n\n”);
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++) /*赋初值值*/
{
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(“****************************************************\n”);
printf(“商品类型 \t 平均价\t 总库存量\n”);
printf(“****************************************************\n”);
printf(“____________________________________________________\n”);
printf(“电器总价值:%0.1f\t平均价:%0.1f\t总库存量:%d\n”,sum[0],aver[0],a[0]);
printf(“____________________________________________________\n”);
printf(“日用品总价值:%0.1f\t平均价:%0.1f\t总库存量:%d\n”,sum[1],aver[1],a[1]);
printf(“____________________________________________________\n”);
printf(“食品总价值:%0.1f\t平均价:%0.1f\t总库存量:%d\n”,sum[2],aver[2],a[2]);
printf(“____________________________________________________\n”);
printf(“办公用品总价值:%0.1f\t平均价:%0.1f\t总库存量:%d\n”,sum[3],aver[3],a[3]);
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 %d\n\n”,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 返回(当你完成了对某一商品的添加、删除或者修改后请按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 %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) /*删除商品*/
{
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;
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 %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==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); /*关闭文件*/
}
void printf0(struct good *p) /*遍历链表并打印电器类商品函数*/
{
struct good *p3; /*定义结构体指针类型*/
p3=p;
while (p3!=NULL) /*判断遍历链表循环结束条件*/
{
if(strcmp(p3-kind,c)==0) /*判断商品类型是否为电器类型*/
{
printf(“%d\t%s\t%s\t%0.1f\t%s\t%d\n”,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(“%d\t%s\t%s\t%0.1f\t%s\t%d\n”,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(“%d\t%s\t%s\t%0.1f\t%s\t%d\n”,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(“%d\t%s\t%s\t%0.1f\t%s\t%d\n”,p3-num,p3-name,p3-kind,p3-price,p3-unit,p3-quantity); /*输出食品类商品信息*/
printf(“________________________________________________\n”);
}
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(“\n****************************\n”);
printf(“商品平均价格排序表(从高到低)\n”);
printf(“****************************\n”);
printf(“________________________________________________\n”);
printf(“编号\t名称\t类别\t单价\t单位\t数量\n”);
printf(“________________________________________________\n”);
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(“\n************************\n”);
printf(“库存量低于100的货名及类别\n”);
printf(“************************\n”);
printf(“________________________\n”);
printf(“商品名称\t商品类型\n”);
printf(“________________________\n”);
while(p1!=NULL) /*判断遍历链表循环结束条件*/
{
if(p1-quantity100) /*判断库存量是否小于100*/
{
printf(“%s\t%s\n”,p1-name,p1-kind); /*输出商品名称及类别*/
printf(“________________________\n”);
}
p1=p1-next;
}
}
void tongji2()
{
printf(“\n**********************************************\n”);
printf(“商品库存量有2种以上(含2种)低于100的商品类别:\n”);
printf(“**********************************************\n”);
printf(“________\n”);
if((a[0]100)(a[0]=2)) /*判断电器类库存量是否为2种以上(含2种)低于100*/
{
printf(“电器\n”);
printf(“________\n”);
}
if((a[1]100)(a[1]=2)) /*判断日用品类库存量是否为2种以上(含2种)低于100*/
{
printf(“日用品\n”);
printf(“________\n”);
}
if((a[2]100)(a[2]=2)) /*判断食品类库存量是否为2种以上(含2种)低于100*/
{
printf(“食品\n”);
printf(“________\n”);
}
if((a[3]100)(a[3]=2)) /*判断办公用品类库存量是否为2种以上(含2种)低于100*/
{
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(); /*调用输出信息函数*/
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; /*结束程序*/
}
C语言程序设计 超市商品信息管理系统
假设某超市经营各种商品,每种商品包括以下信息:商品编号、商品名称、商品品牌、库存数量、售价、已售数量。系统的主要功能包括:1. 创建商品信息文件:根据提示输入若干商品的信息,并将信息保存至一个文件中。2. 商品进货管理喊携:每次购入新商品,敬渗团需按要求输入商品所含各项信息并存入商品信息文件中。如果已经存在该商品(以商品编号为准),则修改相应的库存数量信息,否则生成新的商品信息记录。3. 商品销售管理:每次有商品销售出去,则按要求输入商品编号和商品名称信息,并修改相应的商品信息文件。注意:商品销售时要检查库存数量的合法性(即销售出去的数量必须小于库存数量)。4. 按不同条件进行查询操作,输出满足条件的商品信息。(1) 输入商品名称,在商品信息文件中查找相应的商品信息并输出。(2) 输入商品品牌,在商品信息文件中查找该品牌的所有信息并输出。5. 按不同条件对商品信息进行统计工作。(1) 输入商品名称,亮橘在商品信息文件中统计该商品的销售总额。(2) 设置一个库存数量警戒值,输出库存数量小于该警戒值的所有库存商品的信息。(3) 输入商品品牌,在商品信息文件中统计其不同商品名称的库存量,并输出库存量最高的那个商品的信息。
商品库存管理系统的c语言源代码
#include stdio.h
#include stdlib.h
#include conio.h
struct BOOK
{
int id,usr[10],total,store,days[10];
char name[31],author[21];
}books[100];
/*上面是结构体的定义,用于存放书籍及借书的信息。*/
void page_title(char *menu_item)
{
clrscr();
printf(” 图 书 管 理 系 统 \n\n- %s -\n\n”,menu_item);
}
/*上面是打印页眉的函数,同时通过参数menu_item,可以显示当前的状态。*/
void return_confirm(void)
{
printf(“\n按任意键返回……\n”);
getch();
}
/*上面是返回前请求确认的函数,以便在返回前观察结果*/
int search_book(void)
{
int n,i;
printf(“请输入图书序号:”);
scanf(“%d”,i);
for(n=0;n100;n++)
{
if(books[n].id==i)
{
printf(“书名:%s\n”,books[n].name);
printf(“作者:%s\n”,books[n].author);
printf(“存数:%d of “,books[n].store);
printf(“%d\n”,books[n].total);
return n;
}
}
printf(“\n输入错误或无效图书序号.\n”);
return -1;
}
/*上面的函数是在数组中找到图书号匹配的记录,显示其信息并返
回数组下标,如果找不到相应记录则提示错误并返回-1。*/
void book_out(void)
{
int n,s,l,d;
page_title(“借阅图书”);
if((n=search_book())!=-1books[n].store0)
{
printf(“请输入借书证序号:”);
scanf(“%d”,s);
printf(“请输入可借天数:”);
scanf(“%d”,d);
for(l=0;l10;l++)
{
if(books[n].usr[l]==0)
{
books[n].usr[l]=s;
books[n].days[l]=d;
break;
}
}
books[n].store–;
}
if(n!=-1books[n].store==0) printf(“此书已经全部借出.\n”);
return_confirm();
}
/*上面是借书的函数,首先调用找书函数*/
void book_in(void)
{
int n,s,l;
page_title(“归还图书”);
if((n=search_book())!=-1books[n].storebooks[n].total)
{
printf(“借阅者图书证列表:\n”);
for(l=0;l10;l++)
if (books[n].usr[l]!=0)
printf(“[%d] – %d天世铅\n”,books[n].usr[l],books[n].days[l]);
printf(“请搜喊好输入借书证序号:”);
scanf(“%d”,s);
for(l=0;l10;l++)
{
if(books[n].usr[l]==s)
{
books[n].usr[l]=0;
books[n].days[l]=0;
break;
}
}
books[n].store++;
}
if(n!=-1books[n].store==books[n].total)
printf(“全渗携部入藏.\n”);
return_confirm();
}
void book_add(void)
{
int n;
page_title(“注册新书”);
for(n=0;n100;n++)
if(books[n].id==0) break;
printf(“序号:”);
scanf(“%d”,books[n].id);
C语言设计商品管理系统,可以实现商品的录入,查询,求源代码
#include stdio.h
#include conio.h
#include string.h
#define SIZE 300
typedef struct
{
char name[30];
int num;
char shang[10];
float price;
}record;
void DataInput(record *com, int *nptr);
int DataRead(record *com,int *nptr) ;
void DataStorage(record *com, int n); /*信息保存到文件*/
void DataFind( );
void DataDisPlay( );
void DataAdd( );
void DataDel( );
void DataStatistic( );
int main( )
{
record shangpin[SIZE];
int number=20; /*设商品数*/
char fn;
printf(“\t~~~~~~商品管理系统~~~~~~”);
while(1)
{
printf(“\n\t\t1.商品信息录入\n”); /*显示主菜单*/
printf(“\t\t2.商品信息显示\n”);
printf(“\t\t3.商品信息查找\n”);
printf(“\t\t4.商品信息添加\n”);
printf(“\t\t5.商品信息删除\n”绝迟);
printf(“\t\t6.商品信息统计\n”);
printf(“\t\t0.退出系统”);
printf(“\n\t~~~~~~~~~~~~~~~~\n”);
printf(“\t请输入你的一个选项(数字0-6): “);
fflush(stdin);
scanf(“%c”,fn);
puts(“\n”);
switch(fn) /*切换到不同功能*/
{
case ‘1’:
DataInput(shangpin, number );
break; /*录入信息*/
case ‘2’:DataDisPlay();
break; /*信息显示*/
case ‘3’:
DataFind();
break; /*信息查找*/
case ‘4’:
DataAdd( );
break; /*增加*/
case ‘5’:
DataDel( );
break; /*删除*/
case ‘6’:
DataStatistic();
break; /*信息统计*/
case ‘0’:
return 0;
default:puts(“\t\t没有这个项!返回主菜单!”);
break;
}
printf(“\n\t\t完毕!按任意键继续”);
getch( );
puts(“\n”);
}
}
void DataInput(record *com, int *nptr) /*商品信息录入*/
{
int i = 0;
int n ; /*录入的总数*/
char YesOrNo; /*判断是否保存*/
char shangming[30]; /*商名*/
int haoma; /*商品号*/
char shangjia[10]; /*单价*/
float danjia;
printf(“\t\t请输入商品个数:”);
scanf(“%d”,n);
*nptr = n; /*nptr返回商品个数*/
printf(“\t\t现在侍仔开始录入这%d个商品信息:\n\n”,n);
while(in)
{
printf(“请输入商品的商品名:”,i+1);
scanf(“%s”,shangming);
printf(“请输入并谈李商品的商品号:”,i+1);
scanf(“%d”,haoma);
printf(“请输入商品的生产商:”,i+1);
scanf(“%s”,shangjia);
printf(“请输入商品的单价 :”,i+1);
scanf(“%f”,danjia);
if(danjia=0danjia=1000) /*有效的单价才录入*/
{
strcpy(com[i].name,shangming);
com[i].num = haoma;
strcpy(com[i].shang,shangjia);
com[i].price = danjia;
i =i+1;
}
else
printf(“输入的单价是一个无效的值!!!\n\n”);
} /*结束while*/
printf(“要保存您刚才录入的数据吗(Y/N)?”); /*选择保存*/
fflush(stdin);
scanf(“%c”,YesOrNo);
if(YesOrNo==’y’||YesOrNo==’Y’)
DataStorage(com,n);
else if(YesOrNo==’n’||YesOrNo==’N’)
return;
else
printf(“输入了不正确的选项\n”);
return;
} /*结束函数*/
void DataFind( ) /*查找*/
{
void OnNumber(record *com,int n ); /*按商品号排序*/
int key; /*key为要查找的关键值*/
int low = 0; /*下限*/
int high ; /*上限*/
int mid ; /*中间值*/
char ans; /*选项*/
record com[SIZE];
int n;
if(DataRead(com,n)==1) /*从文件中读取信息*/
{
OnNumber(com,n); /*先按商品号排序*/
high = n;
do
{
printf(“\n\n\t\t请输入你要查找的商品号:”);
scanf(“%d”,key);
low = 0;high = n;
while (low =high)
{
mid = (high + low)/2; /*折半查找法*/
if (key == com[mid].num )
{
printf(“\n\t\t你要找的是第%d个商品\n”,mid + 1);
printf(“\t\t结果如下:\n\n”);
printf(“序号\t\t商品名\t 商品号\t生产商\t单价\n”);
printf(“%3d%17s%12d%12s%8.1f\n”,mid+1,com[mid].name,com[mid].num,com[mid].shang,
com[mid].price);
break; /*如果找到则退出循环*/
}
if (key com[mid].num ) low = mid + 1;
else high = mid – 1;
}
if (low high)
printf(“\t\t,没有找到这个价格!\n”);
printf(“\n\t\t还要继续查询吗(Y/N)?”);
ans = getch( );
}
while (ans ==’Y’||ans == ‘y’); /*结束do….while*/
}
}
void DataStorage(record *com, int n) /*录入保存文件*/
{
int i;
FILE *comPtr;
char FileName[20];
printf(“请输入您要保存的文件名:”);
scanf(“%s”,FileName);
printf(“正在将商品信息保存到文件,请稍候……\n”);
if((comPtr=fopen(FileName,”w”))==NULL)
printf(“没有该文件\n”);
else
for(i=0 ; in ; i++)
fprintf(comPtr,”\n%17s%12d%12s%8.1f”,com[i].name,com[i].num,com[i].shang,com[i].price);
fclose(comPtr);
}
int DataRead(record *com,int *nptr) /*读取文件*/
{
int i=0;
char datafile[20];
FILE *comPtr;
*nptr = 0;
printf(“请输入文件名:”);
scanf(“%s”,datafile);
if((comPtr = fopen(datafile,”r”)) == NULL) /*打开文件*/
{
printf(“没有该文件,请重新输入!\n”);
return 0;
}
else
{
printf(“正在读取商品单价,请稍候……\n”);
while (!feof(comPtr))
{
fscanf(comPtr,”%s%d%s%f”,com[i].name,com[i].num,com[i].shang,com[i].price);
i++;
}
*nptr = i;
printf(“\n”);
fclose(comPtr);
return 1;
}
}
void DataDisPlay()
{
void OnPrice(record *com,int n ); /*按单价*/
void OnNumber(record *com,int n ); /*按商品号*/
int N;
int i;
record com[300];
char YesNo; /*是否按顺序显示*/
char tp;
if(DataRead(com,N)==1) /*从文件读取数据*/
{
printf(“序号\t\t商品名\t 商品号\t生产商\t单价\n”);
for(i=0;iN;i++)
printf(“%3d%17s%12d%12s%8.1f\n”,i+1,com[i].name,com[i].num,com[i].shang,com[i].price);
printf(“要按顺序显示吗?(Y/N)?”);
fflush(stdin);
scanf(“%c”,YesNo);
if(YesNo==’y’||YesNo==’Y’)
{
printf(“\t请输入排序方式:\n”);
printf(“\t(1.按价格排序从低到高;2.按商品号排序从低到高.)”);
fflush(stdin);
scanf(“%c”,tp);
if(tp==’1′)
OnPrice(com,N);
else if(tp ==’2′)
OnNumber(com,N);
else
printf(“\t输入了不正确项!\n”);
}
}
} /*结束显示成绩*/
void OnPrice(record *com,int n ) /*按单价顺序*/
{ int i,j;
record temp;
printf(“\t\t按单价排序—\n\n”);
printf(“商品总数为%d:\n”,n);
for(j=0 ; jn-1 ; j++) /*冒泡排序*/
for(i=0 ; in-j-1 ; i++)
if(com[i].pricecom[i+1].price)
{
temp=com[i];
com[i]=com[i+1];
com[i+1]=temp;
}
printf(“\n\t\t按成绩排序的结果如下(按分数从低到高):\n\n”);
printf(“序号\t\t商品名\t 商品号\t生产商\t单价\n”);
for(i=0 ; in ; i++)
printf(“%3d%17s%12d%12s%8.1f\n”,i+1,com[i].name,com[i].num,com[i].shang,
com[i].price);
}
void OnNumber(record *com,int n ) /*按序号顺序*/
{
int i,j;
record temp;
printf(“\t\t按商品号排序—\n\n”);
printf(“商品总数为%d:\n”,n);
for(j=0 ; jn-1 ; j++)
for(i=0 ; in-j-1 ; i++)
if(com[i].numcom[i+1].num)
{
temp=com[i];
com[i]=com[i+1];
com[i+1]=temp;
}
printf(“\n\t按商品号排序的结果如下(按商品号从小到大):\n\n”);
printf(“序号\t\t商品名\t 商品号\t生产商\t单价\n”);
for(i=0 ; in ; i++)
printf(“%3d%17s%12d%12s%8.1f\n”,i+1,com[i].name,com[i].num,com[i].shang,
com[i].price);
}
void DataAdd( ) /*增加*/
{
int i=0,n,m; /*商品名称*/
char shangming[30];
int haoma; /*生产商*/
char shangjia[10];
float danjia;
char YesOrNo;
record com[SIZE];
printf(“\t\t读取原有数据信息—\n”);
if(DataRead(com,n)==1)
{
printf(“\t\t信息读取完毕!\n\n”);
printf(“\t\t请输入要添加的商品总数:”);
scanf(“%d”,m);
printf(“\t\t现在开始录入这%d个商品信息:\n\n”,m);
while(im)
{
printf(“第%d个商品的商品名:”,i+1);
scanf(“%s”,shangming);
printf(“第%d个商品的商品号:”,i+1);
scanf(“%d”,haoma);
printf(“第%d个商品的生产商:”,i+1);
scanf(“%s”,shangjia);
printf(“第%d个商品的单价:”,i+1);
scanf(“%f”,danjia);
if(danjia=0danjia=1000) /*有效的单价才录入*/
{
strcpy(com[i+n].name,shangming);
com[i+n].num = haoma;
strcpy(com[i+n].shang,shangjia);
com[i+n].price = danjia;
i =i+1;
}
else
printf(“输入的单价是一个无效的值,请重新输入!\n\n”);
}
printf(“要保存您刚才录入的数据吗(Y/N)?”);
fflush(stdin);
scanf(“%c”,YesOrNo);
if(YesOrNo==’y’||YesOrNo==’Y’)
DataStorage(com,n+m);
else if(YesOrNo==’n’||YesOrNo==’N’)
return;
else
printf(“输入了不正确项,返回上一级\n”);
return;
}
}
void DataDel( )//删除
{
void OnNumber(record *com,int n );
record com[SIZE];
int i; /*总记录数*/
int n; /*要删除的记录号*/
int m;
printf(“\t\t读取原有数据信息—\n”);
if(DataRead(com,n)==1)
{
printf(“\t\t原始数据如下:\n\n”);
OnNumber(com,n );
printf(“请输入你要删除的记录的序号”);
scanf(“%d”,m);
if(m=1 m=n)
{
for(i=m-1;in-1;i++)
com [i] = com[i+1];
DataStorage(com,n-1);
}
}
}
void DataStatistic( ) /*统计信息*/
{
int high=0,low=200,ave=0;
int n,i,sum=0;
int g,l;
record com[SIZE];
printf(“读取数据信息—\n”);
if(DataRead(com,n)==1)
{
printf(“商品总数为%d\n\n”,n);
for(i=0;in;i++)
{
if(com[i].pricehigh)
{
high = com[i].price;
g=i;
}
if(com[i].pricelow)
{
low = com[i].price;
l=i;
}
sum += com[i].price;
}
ave=sum/n;
printf(“\t\t最高\t最低\t平均\n”); /*计算值*/
printf(“商品单价统计:\t%d\t%d\t%d\n\n”,high,low,ave);
printf(“序号\t\t商品名\t 商品号\t生产商\t单价\n”);
for(i=0 ; in ; i++)
printf(“%3d%17s%12d%12s%8.1f\n”,i+1,com[i].name,com[i].num,com[i].shang,
com[i].price);
printf(“\t\t 序号\t\t 商品名\t 商品号\t 生产商 单价\n”);
printf(“单价最高的商品是:%3d%17s%12d%12s%8.1f\n\n”,g+1,com[g].name,com[g].num,com[g].shang,com[g].price);
printf(“单价最低的商品是:%3d%17s%12d%12s%8.1f\n”,l+1,com[l].name,com[l].num,com[l].shang,com[l].price);
} /*结束统计*/
}
用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(“————————————————————————-\n”);
printf(“****************欢迎使用超市管理系统*******************\n”);
printf(“————————————————————————-\n”);
}
void mainMenu()//功能浏览界面
{
printf(“****1.购物结算****\n”);
printf(“****2.进货管理****\n”);
printf(“****3.修改商品****\n”);
printf(“****4.显示商品****\n”);
printf(“****5.删穗厅除商品****\n”);
printf(“****0.退出系统****\n”);
}
//查询信息
int searchGoods()//查询商品信息
{
printf(“请输入您要购买商品的名字:”);
scanf(“%s”,name);
for(int i=0;icount;i++)
{
if(stricmp(name,list[i].name)==0)
{
return 1;
}
else
{
printf(“对不起了,没有找到%c商品\n”,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\n”,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(“商品名称\t数量\t单价\n”);
for(int i=0;icount;i++)
{
printf(“%s\t%d\t%.2f\n”,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语言做一个顺序表的超市管理系统,需要能进行增,删,改,查,插入,排序
typdef struct chao shi
{
char name[20];//商品名
int amount;//商品数量
double price;// 商品价格
struct chao shi*next;
}linklist;
linklist *creatlist();//创立链表return head;
void insert(linklist*p);//传入链表的首地址,插入函数ps:插入就是增加啊!
void change(linklist*p);/袜毕则/修改商品价格和数量!
void del(linklist*p);删除商品信息!
void sort(linklist*p);//排序
void find(linklist*p);//查找(里面包含输出)
void output(linklist*p);//输出函数
int menu()
void main()
ok!你自己会写了ba?我做了一个学生信息管理系统你看看吧可以参考下!
#includestdio.h
#includestdlib.h
#includestring.h
#define M 3
typedef struct node
{
char sno[20];
char name[20];
int score[M];
double avg;
struct node *next;
}linklist;
int listlength(linklist*head);
void output1(linklist*head);
void output2(linklist*head);
linklist *create()
{
linklist *head,*p,*t;
int n,i,j;
printf(“请输入学生人数:”);
scanf(“%d”,n);
head=(linklist*)malloc(sizeof(linklist));
t=head;
for(i=0;in;i++)
{
p=(linklist*)malloc(sizeof(linklist));
printf(“输入学号:”);
scanf(“%s”,p-sno);
printf(“输入姓名:”);
scanf(“%s”,p-name);
printf(“输入%d门功课成绩:”,M);
for(j=0;jM;j++)
scanf(“%d”,p-score[j]);
printf(“\n”);
t-next=p;
t=p;
}
p-next=NULL;
return head;
}
void insert(linklist*head)
{
linklist *p;
int i,n,j;
printf(“输入你要插入的数猜学生人数:”);
scanf(“%d”,n);
printf(“你要插入的学生信息:\n”);
for(i=0;in;i++)
{p=(linklist*)malloc(sizeof(linklist));
p-next=head-next;
head-next=p;
printf(“输入学号:”);
scanf(“%s”,p-sno);
printf(“输入姓名:”);
scanf(“%s”,p-name);
printf(“输入%d门功课成绩:”,M);
for(j=0;jM;j++)
scanf(“%d”,p-score[j]);
}
}
void del(linklist*head)
{
linklist *p,*q;
char s[20];
printf(“输入要删除学生的姓名:”);
scanf(“%s”,s);
q=head;
p=head-next;
while(strcmp(p-name,s)!=0p)
{ q=p;
p=p-next;}
if(p==NULL)
printf(“无此人\n”);
else
{q-next=p-next;
free(p);}
}
void change(linklist*head)
{
linklist*p;//修改学生信息模块!
int i,a[M];//M=3
char s[20];//存放学生姓名的数组!
printf(“输入你要修改数据的学生姓名:”);
scanf(“%s”,s);
p=head-next;
while(strcmp(p-name,s)!=0p)//遍历链表告棚
p=p-next;
if(p==NULL)
printf(“无此人\n”);
else
{ printf(“%s\t%s\t”,p-sno,p-name);
printf(“请重新输入学生的%d门成绩:”,M);
for(i=0;iM;i++)
{scanf(“%d”,a[i]);
p-score[i]=a[i];}
}
}
void sort(linklist*head)
{ double sum;//用学生的平均分进行排序!
linklist *p,*q,*t;
int i,j;
double temp;
int m=listlength(head);//求出链表长度的函数!(因为链表长度有变化所以写了这个函数)
q=p=head-next;
for(i=0;im;i++)
{
sum=0;
for(j=0;jM;j++)//求出学生M门功课的成绩平均分
sum+=q-score[j];
p-avg=sum/M;
p=p-next;
q=p;
}
output2(head);
p=head-next;
printf(“有不及格科目的学生:\n”);
for(i=0;im;i++)
{ for(j=0;jM;j++)
if(p-score[j]60)
{ printf(“%s\t%s\t”,p-sno,p-name);
for(j=0;jM;j++)
printf(“%d “,p-score[j]);
printf(“\n”);
}
p=p-next;
}
printf(“\n”);
printf(“学生成绩排序:\n”);
t=NULL;
while(t!=head-next)
{
p=head;
q=p-next;
while(q-next!=t)
{
if(p-next-avgq-next-avg)
{
p-next=q-next;
q-next=q-next-next;
p-next-next=q;
}
p=p-next;
q=p-next;
}
t=q;
}
}
int listlength(linklist*head)
{
int n=0;
linklist*p;
p=head-next;
while(p)
{n++;
p=p-next;
}
return n;
}
int menu()
{
int m,i;
printf(“============================================================\n”);
printf(“||1:录入学生数据 2:增加学生数据 ||\n”);
printf(“||3:删除学生数据 4:改正学生数据 ||\n”);
printf(“||5:排序 6:退出。 ||\n”);
printf(“||=========================================================\n”);
printf(“输入你要选择的功能:”);
i=scanf(“%d”,m);
system(“cls”);
fflush(stdin);
return m;
}
void output1(linklist*head)
{
linklist*p;
int i;
p=head-next;
while(p)
{
printf(“%s\t%s\t”,p-sno,p-name);
for(i=0;iM;i++)
printf(“%d “,p-score[i]);
p=p-next;
printf(“\n”);
}
}
void output2(linklist*head)
{
linklist*p;
int i;
p=head-next;
while(p)
{
printf(“%s\t%s\t”,p-sno,p-name);
for(i=0;iM;i++)
printf(“%d “,p-score[i]);
printf(“%lf”,p-avg);
p=p-next;
printf(“\n”);
}
}
int main(void)
{
linklist*p;
int k=0;
do
{
k=menu();
switch(k)
{
case 1:
p=create();
output1(p);break;
case 2:insert(p);
output1(p);break;
case 3:del(p);
output1(p);break;
case 4:change(p);
output1(p);break;
case 5:sort(p);
output2(p);break;
case 6:exit(0);
}
}while(k=1k=6);
return 0;
}