⑴ c语言程序设计 超市商品信息管理系统
假设某超市经营各种商品,每种商品包括以下信息:商品编号、商品名称、商品品牌、库存数量、售价、已售数量。系统的主要功能包括:1. 创建商品信息文件:根据提示输入若干商品的信息,并将信息保存至一个文件中。2. 商品进货管理:每次购入新商品,需按要求输入商品所含各项信息并存入商品信息文件中。如果已经存在该商品(以商品编号为准),则修改相应的库存数量信息,否则生成新的商品信息记录。3. 商品销售管理:每次有商品销售出去,则按要求输入商品编号和商品名称信息,并修改相应的商品信息文件。注意:商品销售时要检查库存数量的合法性(即销售出去的数量必须小于库存数量)。4. 按不同条件进行查询操作,输出满足条件的商品信息。(1) 输入商品名称,在商品信息文件中查找相应的商品信息并输出。(2) 输入商品品牌,在商品信息文件中查找该品牌的所有信息并输出。5. 按不同条件对商品信息进行统计工作。(1) 输入商品名称,在商品信息文件中统计该商品的销售总额。(2) 设置一个库存数量警戒值,输出库存数量小于该警戒值的所有库存商品的信息。(3) 输入商品品牌,在商品信息文件中统计其不同商品名称的库存量,并输出库存量最高的那个商品的信息。
⑵ 100 求C语言超市管理系统的代码现在需要为一家超市设计一款交易管理系统,需要实现以下功能
你好!
很多相同的课题,只有类似的,,没有完全一样 的,只能修改源程序
⑶ 谁能帮我用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?我做了一个学生信息管理系统你看看吧可以参考下!
#include<stdio.h>
#include<stdlib.h>
#include<string.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;i<n;i++)
{
p=(linklist*)malloc(sizeof(linklist));
printf("输入学号:");
scanf("%s",p->sno);
printf("输入姓名:");
scanf("%s",p->name);
printf("输入%d门功课成绩:",M);
for(j=0;j<M;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;i<n;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;j<M;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)!=0&&p)
{ 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)!=0&&p)//遍历链表
p=p->next;
if(p==NULL)
printf("无此人\n");
else
{ printf("%s\t%s\t",p->sno,p->name);
printf("请重新输入学生的%d门成绩:",M);
for(i=0;i<M;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;i<m;i++)
{
sum=0;
for(j=0;j<M;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;i<m;i++)
{ for(j=0;j<M;j++)
if(p->score[j]<60)
{ printf("%s\t%s\t",p->sno,p->name);
for(j=0;j<M;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->avg<q->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;i<M;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;i<M;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>=1&&k<=6);
return 0;
}
⑷ 用c语言实现超市商品管理系统,用指针实现商品的插入和删除
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
typedefstructnode{
charno[20];//存放编号
charname[40];//存放名称
intreserve;//库存
structnode*next;
}NODE;
typedefstructlink{
NODE*front;//头指针
NODE*rear;//尾指针
}LINK;
NODE*create_node(void){
NODE*node=(NODE*)malloc(sizeof(NODE));
printf("请输入货物编号:");
gets(node->no);
printf("请输入货物名称:");
gets(node->name);
printf("请输入货物名称:");
charch;
while((ch=getchar())!=' ');//rewind(stdin);
scanf("%d",&node->reserve);
node->next=NULL;
returnnode;
}
voidinit_link(LINK*link){
link->rear=NULL;
link->front=NULL;
}
intlink_empty(LINK*link){
returnlink->front==NULL?1:0;
}
intnode_num(LINK*link){
intnum=0;
if(link_empty(link)){
returnnum;
}
num=1;
NODE*node=link->front;
while(node!=link->rear){
node=node->next;
++num;
}
returnnum;
}
/*NODE*node_find(LINK*link,constintn){
intnum=node_num(link);
if(num<n){
printf("公有节点%d个,无法找到第%d个节点 ",num,n);
}
else{
}
}
*/
voidnode_push(LINK*link){
NODE*node=create_node();
if(link->front==NULL){
link->front=node;
link->rear=node;
node->next=NULL;
}
else{
link->rear->next=node;
link->rear=node;
node->next=NULL;
}
}
voidnode_insert(LINK*link,constintn){
intnum=0,i=1;
NODE*node=link->front;
NODE*new_node=NULL;
if(link_empty(link)){
printf("链表为空,将建立链表! ");
node_push(link);
}
else{
if(n<=1){
printf("在链表头插入数据 ");
new_node=create_node();
new_node->next=link->front;
link->front=new_node;
}
elseif(n>=num=node_num(link)){
printf("节点数少于%d,将在末尾插入节点. ",n);
node_push(link);
}
else{
printf("在第n个节点后插入数据 ");
if(num>=n){
while(i!=n){
node=node->next;
++i;
}
new_node=create_node();
new_node-next=node->next;
node->next=new_node;
}
}
}
voidfind_node_insert(LIKNK*link,constchar*name){
NODE*node=link->front;
if(link_empty(link))
node_push(link);
else{
while(strcmp(node->name,name)!=0){
if(node!=link->rear)
node=node->next;
elsebreak;
}
if(node!=NULL){
NODE*new_node=create_node();
new_node-next=node->next;
node->next=new_node;
}
else{
printf("没有找到相关货物,将在头节点插入数据 ");
intsert(link,0);
}
}
⑸ c语言超市商品管理系统,要有商品的录入查找删除添加等功能。用链表实现插入删除功
有个以前练习写的。
//利用单链表编写一个学生成绩系统。(具有查询成绩、修改成绩、删除成绩、添加成绩、全班平均等功能。)
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define MAXSIZE 100
typedef char nametype;
typedef float gradetype;
typedef struct node{
nametype name[MAXSIZE];
gradetype grade;
struct node *next;
}linklist,*plinklist;
plinklist init(){
plinklist L;
L=(plinklist)malloc(sizeof(linklist));
;
L->next =NULL;
return L;
}
plinklist creat_tail(plinklist L){
plinklist s;
printf("name & grade:");
s=(plinklist)malloc(sizeof(linklist));
scanf("%s%f",s->name,&s->grade);
s->next=L->next;
L->next=s;
return L;
}
plinklist locate_name(plinklist L,nametype x[]){
plinklist p;
p=L;
while(p->next!=NULL){
p=p->next;
if(strcmp(p->name,x)==0)return p;
}
return NULL;
}
int delete_list(plinklist L,plinklist p){
plinklist q=L;
while(q->next!=NULL){
if(q->next ==p) break;
q=q->next ;
}
if(q->next ==p){
q->next =p->next ;
free(p);
return 1;
}
else{
printf("不在该表中\n");
return 0;
}
}
/*********平均分数***********/
void average(plinklist L){
float i;
float sum=0.0;
plinklist p=L;
for(i=0;p->next!=NULL;i++){
p=p->next ;
sum=sum+p->grade;
}
printf("%.2f\n",sum/i);
}
/*******添加成绩*************/
void insert_linklist(plinklist L){
L=creat_tail(L);
putchar(10);
printf("insert succeed\n");
}
/**********成绩查找**********/
void locate(plinklist L){
nametype name[MAXSIZE];
plinklist p;
printf("name search:");
scanf("%s",name);
putchar(10);
p=locate_name(L,name);
printf("%s %.2f\n",p->name,p->grade);
}
/**********修改成绩**************/
void Amendment(plinklist L){
nametype name[MAXSIZE];
plinklist p;
printf("name:");
scanf("%s",name);
putchar(10);
p=locate_name(L,name);
printf("输入修改信息,姓名与分数:");
scanf("%s%f",p->name,&p->grade);
printf("\nAmendment succeed\n");
}
/**********删除成绩*********/
void del(plinklist L){
nametype name[MAXSIZE];
plinklist p;
printf("name delete:");
scanf("%s",name);
putchar(10);
p=locate_name(L,name);
if(delete_list(L,p))
printf("delete succeed\n");
}
main()
{
int n,i;
/******创建学生信息*********/
plinklist H;
H=init();
printf("输入学生数量");
scanf("%d",&n);
for(i=0;i<n;i++)
H=creat_tail(H);
putchar(10);
printf("*****成绩查询*****\n");
locate(H);
printf("****修改成绩*****\n");
Amendment(H);
printf("****删除成绩*****\n");
del(H);
printf("****添加成绩*****\n");
insert_linklist(H);
printf("****全班平均*****\n");
average(H);
}
⑹ 用C语言程序编写一个超市商品管理系统设计
有偿帮你写
⑺ 求C语言小型超市管理系统代码
http://blog.csdn.net/xuhang0910/article/details/46366831
看看增加点知识,可能对你有帮助
⑻ C语言课程设计 超市管理系统,用链表做,是什么思路,那个大佬能帮帮忙给个思路,链表的存储怎么弄的
你这超市管理系统要什么功能也没说,你按照下面的基础代码去写,自己先试着完成,多跟同学交流讨论。这种应用型的题目最好是自己完成,不要去网上找代码。
struct super_system{
//属性列表
//********
struct super_system* next;//
};
⑼ 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;i<4;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;i<4;i++)
g[i]=aver[i]; /*将平均价赋给新数组*/
for(j=0;j<3;j++) /*将新数组用冒泡排序法排序*/
for(i=j+1;i<4;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;j<4;j++)
for(i=0;i<4;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->quantity<100) /*判断库存量是否小于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语言设计一个超市管理系统程序,要求能添加商品,能查询商品,能购买商品,能展示商品。
超市管理系统
*/
#include<stdio.h>
#include<string.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;i<count;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;i<count;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;i<count;i++)
{
list[i].num+=number;//list[i].num=list[i].num+number
}
}
//显示货物信息
void showGoods()
{
printf("商品名称\t数量\t单价\n");
for(int i=0;i<count;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;i<count;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;i<count;i++)
{
if(strcmp(name,list[i].name)==0)
{
index=i;
}
}if(index==-1)
{
printf("对不起!没有找到您要删除的商品信息!");
}
else{
for(int i=index;i<count;i++)
{
list[i]=list[i+1];
}
}
}