#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define NUM 5
/* 【自学去】网站收集 http://www.zixue7.com */
struct item{
char brand[20];
char id[10];
float in_price;
float out_price;
int storage;
};
struct item_node{
struct item wanted;
int amount;
struct item_node *next;
};
int menu();
void establish();
void dis_all();
void shop_cart();
int cart_menu();
void add();
void display();
void calculate();
struct item goods[NUM];
struct item_node *cart;
void main()
{
printf("***********************************\n");
printf(" 欢迎进入超市管理系统\n");
printf("***********************************\n");
while(1)
{
switch(menu())
{
case 1:
establish();break;
case 2:
dis_all();break;
case 3:
shop_cart();break;
case 4:
calculate();break;
case 5:
printf("感谢使用,再见!\n");
exit(0);
}
}
}
int menu()
{
char str[5];
int select;
printf("\n\n请选择数字进行操作\n");
printf("1.建立库存信息\n");
printf("2.显示所有信息\n");
printf("3.购物车\n");
printf("4.结算\n");
printf("5.退出\n");
printf("请选择对应数字1--5");
while(1)
{
fflush(stdin);
gets(str);
select=atoi(str);
if(select<1||select>5)
printf("输入错误,请重新输入:");
else
break;
}
return select;
}
void dis_all()
{
int i;
FILE *fp;
fp=fopen("goods","r");
for(i=0;(fread(goods+i,sizeof(struct item),1,fp))!=0;i++)
{
printf("---------------------------------\n");
printf("货品 品名 单价 库存量\n");
printf("%s%7s%7.2f%8d\n",goods[i].id,goods[i].brand,goods[i].out_price,goods[i].storage);
}
fclose(fp);
}
void shop_cart()
{
while(1)
{
switch(cart_menu())
{
case 1:
display();break;
case 2:
add();break;
case 3:
return;
}
}
}
int cart_menu()
{
char str[5];
int select;
printf("\n请选择操作\n");
printf("-----------------------\n");
printf("1.显示当前购物列表\n");
printf("2.添加商品\n");
printf("3.退出\n");
printf("-----------------------\n\n");
while(1)
{
fflush(stdin);
gets(str);
select=atoi(str);
if(select<1||select>3)
printf("输入错误,请重新输入:");
else
break;
}
return select;
}
void display()
{
struct item_node *p=cart;
if(p==NULL){
printf("购物车为空\n");
return ;
}
while(p!=NULL){
printf("----------------------------------\n");
printf("货号 品名 单价 数量\n");
printf("%10s%20s%7.2f%8d\n",p->wanted.id,p->wanted.brand,p->wanted.out_price,p->amount);
p=p->next;
}
}
void add()
{
FILE *fp;
int i,n;
char str[20];
char choice1,choice2;
struct item_node *p,*p1;
do
{
printf("输入所需物品的名称或货号: ");
fflush(stdin);
gets(str);
if((fp=fopen("goods","r"))==NULL){
printf("打开文件失败\n");
continue;
}
for(i=0;fread(goods+i,sizeof(struct item),1,fp)!=0;i++){
if((strcmp(goods[i].brand,str)==0||strcmp(goods[i].id,str)==0)&&goods[i].storage!=0){
printf("已经找到所需物品: \n");
printf("---------------------\n");
printf("货号 品名 单价 库存量\n");
printf("%s%6s%3.2f%4d\n",goods[i].id,goods[i].brand,goods[i].out_price,goods[i].storage);
printf("请输入所需数量: ");
scanf("%d",&n);
if(n>goods[i].storage){
printf("库存不足\n");
break;
}
printf("\n是否购买?(Y/N)");
fflush(stdin);
choice1=getchar();
if(choice1=='Y'||choice1=='y'){
p1=(struct item_node*)malloc(sizeof(struct item_node));
if(p1==NULL){
printf("内存申请失败!\n");
exit(1);
}
p1->amount=n;
p1->wanted=goods[i];
p1->next=NULL;
p=cart;
if(cart==NULL)
cart=p1;
else{
while(p->next!=NULL)
p=p->next;
p1->next=p->next;
p->next=p1;
}
}
break;
}
}
if(i==NUM)
printf("未找到所需物品\n");
fclose(fp);
printf("是否继续购物?(Y/N)");
fflush(stdin);
choice2=getchar();
}while(choice2=='Y'||choice2=='y');
}
void establish(){
FILE *fp;
int i;
printf("请依次输入货物信息:\n");
printf("----------------------------\n");
for(i=0;i<NUM;i++)
{
printf("品名: ");
fflush(stdin);
gets(goods[i].brand);
printf("货号: ");
fflush(stdin);
gets(goods[i].id);
printf("进价: ");
fflush(stdin);
scanf("%f",&goods[i].in_price);
printf("哨价: ");
fflush(stdin);
scanf("%f",&goods[i].out_price);
printf("数量: ");
fflush(stdin);
scanf("%d",&goods[i].storage);
printf("\n");
}
if((fp=fopen("goods","w"))==NULL){
printf("创建文件失败.\n");
return;
}
fwrite(goods,sizeof(struct item),NUM,fp);
fclose(fp);
}
void calculate()
{
float total=0,pay;
struct item_node *p;
int i;
FILE *fp;
printf("以下是购物清单: \n");
display();
if((fp=fopen("goods","r"))==NULL){
printf("打开文件失败: \n");
return;
}
for(i=0;(fread(goods+i,sizeof(struct item),1,fp))!=0;i++);
fclose(fp);
p=cart;
while(p!=NULL){
total+=p->wanted.out_price*p->amount;
for(i=0;strcmp(goods[i].id,p->wanted.id)!=0;i++);
goods[i].storage-=p->amount;
p=p->next;
}
printf("总计 %7.2f",total);
printf("\n输入实付金额: ");
scanf("%f",&pay);
printf("实付: %7.2f 找零: %7.2f",pay,pay-total);
if((fp=fopen("goods","w"))==NULL){
printf("打开文件失败.\n");
return;
}
fwrite(goods,sizeof(struct item),NUM,fp);
fclose(fp);
}
没有合适的资源?快使用搜索试试~ 我知道了~
温馨提示
【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、python、web、C#、EDA、proteus、RTOS等项目的源码。【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。
资源推荐
资源详情
资源评论
收起资源包目录
基于C语言实现C语言超市管理系统(含源代码+使用说明).rar (1个子文件)
C语言超市管理系统
C语言超市管理系统
system.cpp 5KB
共 1 条
- 1
资源评论
CrMylive.
- 粉丝: 1w+
- 资源: 4万+
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- C++-leetcode题解之002. Add Two Numbers.cpp
- C++-leetcode题解之001. Two Sum.cpp
- C++-leetcode题解之2553-Separate-the-Digits-in-an-Array.cpp
- C++-leetcode题解之1310-XOR-Queries-of-a-Subarray.cpp
- C++-leetcode题解之1248-count-number-of-nice-sub-arrays.cpp
- C++-leetcode题解之923-3-sum-with-multiplicity.cpp
- C++-leetcode题解之668-Kth-Smallest-Number-in-Multiplication-Table
- C++-leetcode题解之412-Fizz-Buzz.cpp
- C++-leetcode题解之282-Expression-Add-Operators.cpp
- C++-leetcode题解之206-Reverse-Linked-List.cpp
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功