XMU C语言程序设计实践(5)
• 使用动态链表完成一个简单的商品库存信息管理系统。
• 商品信息包括如下字段:商品号、商品名称、商品库存
• 函数
create:接收用户输入的商品号和商品名称的信息,建立链表;库存初始化为0,没有进货之前不允许销售;商品号为0表示用户输入结束。本函数用于初始化,如果第二次被调用的时候,首先要执行destroy清除旧链表。
destroy:给定链表的头指针,删除链表的所有节点,并释放相应的空间。本函数在程序退出前应至少被调用一次。在调用此函数前,必须给予用户提示,使用户在删除前有反悔的机会。
sell:商品销售,由参数传入商品号和销售数量。如果不存在给定商品号的商品或销售数量大于相应商品的库存则出错;否则,从指定商品的库存中扣除相应的销售数量。当商品库存为0,则从链表中删除该商品。
stock:商品进货,由参数传入商品号和进货数量。如果不存在给定商品号的商品则在链表中插入新商品,并提示用户输入该商品名称;否则,增加指定商品的库存量。
list:列出所有商品的情况。
• 主程序
程序运行后,循环显示如下菜单:
1. 输入商品信息2. 销售3. 进货4. 列举商品信息5. 清除所有商品6.退出根据用户的选择进一步提示用户输入并调用对应函数。
//
//by coolxxx
//
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<math.h>
#define min(a,b) ((a)<(b)?(a):(b))
#define max(a,b) ((a)>(b)?(a):(b))
#define abs(a) ((a)>0?(a):(-(a)))
#define lowbit(a) (a&(-a))
#define sqr(a) ((a)*(a))
#define swap(a,b) ((a)^=(b),(b)^=(a),(a)^=(b))
#define eps (1e-8)
#define J 10000000
#define MAX 0x7f7f7f7f
#define PI 3.1415926535897
#define N 104
typedef long long LL;
int cas,cass;
int n,m,lll,ans;
int mark1,mark2,mark5;//mark1=1商品非空 mark2=1 已经进货 mark5=1已经清空
//typedef struct xxx xxx;
struct xxx
{
int num,sum;
char name[N];
struct xxx * next;
};
void destroy(struct xxx *h)
{
if(h->next==NULL)
{
mark1=;
mark5=;
puts("清除完毕");
return;
}
struct xxx *p=(struct xxx *)malloc(sizeof(struct xxx)*);
struct xxx *q=(struct xxx *)malloc(sizeof(struct xxx)*);
p=h->next;
while(p!=NULL)
{
q=p->next;
p=NULL;
free(p);
p=q;
}
h->next=NULL;
mark1=;
mark5=;
puts("清除完毕");
}
void create(struct xxx *h)
{
int xnum;
puts("请输入商品号和商品名称,以商品号为0结束");
while(scanf("%d",&xnum) && xnum)
{
struct xxx *p=(struct xxx *)malloc(sizeof(struct xxx)*);
p->next=h->next;
p->num=xnum;
p->sum=;
h->next=p;
scanf("%s",p->name);
}
mark1=;
mark5=;
}
void stock(struct xxx *h,int xnum,int xsum)
{
struct xxx *p=(struct xxx *)malloc(sizeof(struct xxx)*);
for(p=h->next;p!=NULL && p->num!=xnum;p=p->next);
if(p!=NULL)
{
p->sum+=xsum;
printf("进货完成,现在%d号商品库存为%d",p->num,p->sum);
return;
}
else
{
puts("商品不在清单内,现已加入清单,请输入商品名称");
struct xxx *p=(struct xxx *)malloc(sizeof(struct xxx)*);
p->next=h->next;
h->next=p;
p->num=xnum;
p->sum=xsum;
scanf("%s",p->name);
printf("进货完成,现在%d号商品库存为%d",p->num,p->sum);
}
mark2=;
}
void sell(struct xxx *h,int xnum,int xsum)
{
struct xxx *p=(struct xxx *)malloc(sizeof(struct xxx)*);
for(p=h->next;p!=NULL && p->num!=xnum;p=p->next);
if(p!=NULL)
{
if(p->sum<xsum)
{
puts("商品库存小于销售数量,请核对后再进行销售");
return;
}
p->sum-=xsum;
printf("销售完成,%d商品剩余%d库存",p->num,p->sum);
}
else
{
puts("商品不在货物清单内,请核对后再进行销售");
}
}
void list(struct xxx *h)
{
if(h->next==NULL)
{
puts("商品列表为空");
return;
}
puts("商品列表如下:");
struct xxx *p=(struct xxx *)malloc(sizeof(struct xxx)*);
for(p=h->next;p!=NULL;p=p->next)
{
printf("%-4d%-10s%-4d\n",p->num,p->name,p->sum);
}
puts("");
}
void work1(struct xxx *h)
{
if(mark1)
{
puts("当前商品列表非空,如果要生成商品列表需要先清空商品列表\n确定清空商品列表请输入1,取消请输入0");
scanf("%d",&cas);
if(cas==)
{
puts("您已取消清空列表");
return;
}
destroy(h);
}
puts("现在开始输入货物清单");
create(h);
}
void work2(struct xxx *h)
{
int xnum,xsum;
if(!mark2)
{
puts("商品还未进货,请先进货再进行销售");
return;
}
puts("请输入需要销售的商品号和销售数量");
scanf("%d%d",&xnum,&xsum);
sell(h,xnum,xsum);
}
void work3(struct xxx *h)
{
int xnum,xsum;
puts("请输入进货的商品号和商品数量");
scanf("%d%d",&xnum,&xsum);
stock(h,xnum,xsum);
}
void work4(struct xxx *h)
{
list(h);
}
void work5(struct xxx *h)
{
puts("即将删除所有商品!\n确定请输入1,取消请输入0");
scanf("%d",&cas);
if(cas==)
{
puts("您已取消删除所有商品");
return;
}
destroy(h);
}
int main()
{
#ifndef ONLINE_JUDGE
// freopen("1.txt","r",stdin);
// freopen("2.txt","w",stdout);
#endif
int i,j;
struct xxx *head=(struct xxx *)malloc(sizeof(struct xxx)*);
head->next=NULL;
while()
{
puts("1.输入商品信息\n2.销售\n3.进货\n4.列举商品信息\n5.清除所有商品\n6.退出");
scanf("%d",&cass);
if(cass==)work1(head);
else if(cass==)work2(head);
else if(cass==)work3(head);
else if(cass==)work4(head);
else if(cass==)work5(head);
else if(cass==)
{
if(mark5)break;
puts("您还未清除所有商品,请清除所有商品后再退出");
}
puts("\n");
}
return ;
}
/*
// //
*/
XMU C语言程序设计实践(5)的更多相关文章
- XMU C语言程序设计实践(1)
题目: 任务1:英雄出世 炎热的夏天午后,小明正在百无聊赖地写c语言程序.忽然,电脑屏幕一阵抖动,浮现下面18×18个看似杂乱无章的数字: 32, 32, 32, 32, 32, 32, ...
- XMU C语言程序设计实践(4)
以下实验二选一. 1.使用队列实现迷宫算法,找到最短路径. 2.实现顺序队列和链队列的所有基本操作,InitQueue(&Q):DestroyQueue(&Q):ClearQueue( ...
- XMU C语言程序设计实践(3)
问题描述: 以一个n的长方阵表示迷宫,0和1分别表示迷宫中的通路和障碍,设计一个程序,对任意设定的迷宫,求出一条从入口到出口的通路,或得出没有通路的结论. 对于本问题需用栈实现“穷举求解”算法,即:从 ...
- XMU C语言程序设计实践(2)
任务一:颠倒的世界 小明最近突然喜欢倒着写字,写出来的句子全是颠倒的,也就是把一句话里的字符全都逆序写,譬如“I Love This Game!”,他就偏偏要写成“!emaG sihT evoL I” ...
- 第二章 C语言编程实践
上章回顾 宏定义特点和注意细节 条件编译特点和主要用处 文件包含的路径查询规则 C语言扩展宏定义的用法 第二章 第二章 C语言编程实践 C语言编程实践 预习检查 异或的运算符是什么 宏定义最主要的特点 ...
- C语言程序设计课程总结
第一次教授C语言程序设计课程,相比计算机组成原理.arm体系结构等偏向硬件的课程,C的教学方式要灵活一些.计算机组成原理课程偏向理论,哈尔滨工业大学的计算机组成原理是国家精品课,增加了mooc+spo ...
- 【任务】Python语言程序设计.MOOC学习
[博客导航] [Python导航] 任务 18年11月29日开始,通过9周时间跨度,投入约50小时时间,在19年1月25日之前,完成中国大学MOOC平台上的<Python语言程序设计>课程 ...
- 2019年春季学期《C语言程序设计II》助教注意事项
本学期<C语言程序设计II>课程安排 理论课时24(1-12周),实验课时8(13周),课程设计课时16(14-15周) 理论课教学内容 附:教学进度表 本学期实验课和课程设计参考教材 & ...
- C语言程序设计实习报告
C语言程序设计实习报告 简介 语言实践心得体会范文在科技高度发展的今天,计算机在人们之中的作用越来越突出.而c语言作为一种计算机的语言,我们学习它,有助于我们更好的了解计算机,与计算机进行交流,因此, ...
随机推荐
- Redis常见配置redis.conf
redis的配置文件.相信学过SSH或SSM的读者都知道,配置文件的使用在当下开发已十分普遍,希望大家要熟悉习惯这 种开发方式,废话不多说,来开始我们今天的内容吧. 首先得找到 redis 的配置文件 ...
- 【2018.10.18】noip模拟赛Day2 地球危机(2018年第九届蓝桥杯C/C++A组省赛 三体攻击)
题目描述 三体人将对地球发起攻击.为了抵御攻击,地球人派出了 $A × B × C$ 艘战舰,在太 空中排成一个 $A$ 层 $B$ 行 $C$ 列的立方体.其中,第 $i$ 层第 $j$ 行第 $k ...
- J2ME开发入门
原文发布时间为:2008-07-31 -- 来源于本人的百度文章 [由搬家工具导入] J2ME开发入门J2ME方面开发的资料,确实是少之又少,一般给新手推荐的都是王森先生的《PDA与手机开发入门》一书 ...
- 标准C程序设计七---10
Linux应用 编程深入 语言编程 标准C程序设计七---经典C11程序设计 以下内容为阅读: <标准C程序设计>(第7版) 作者 ...
- py3.6 + xadmin的自学网站搭建
xadmin安装 由于安装时需要依赖包并且暂时不支持py3等原因,直接pip install的方法很容易就狗带了. 说一下我在网上找到的安装方式,在GitHub上有这个项目的开源代码,并且还有很多个版 ...
- Objective C语言中nil、Nil、NULL、NSNull的区别
以下内容是基于搜集整理的网上资料,供参考. nil:指向Objective C语言中对象的空指针,其定义值为(id)0. Nil:指向Objective C语言中类(Class)的空指针,其定义值为( ...
- 2014湘潭全国邀请赛I题 Intervals /POJ 3680 / 在限制次数下取有权区间使权最大/小问题(费用流)
先说POJ3680:给n个有权(权<10w)开区间(n<200),(区间最多数到10w)保证数轴上所有数最多被覆盖k次的情况下要求总权最大,输出最大权. 思路: 限制的处理:s ...
- LINUX下面NetworkManager和network冲突的问题
https://blog.csdn.net/ID_EAGLE/article/details/74085409
- Hbase优化总结
1.JVM参数优化: –Xmn=12G –Xms=24G -Xmx=24G 根据实际机器情况调整,一般为整个机器内存的一半,同时建议regionServer的堆内存建议不要超过32G ; -XX: ...
- 【Vue 学习系列 - 01】- 环境搭建(Win7)
1. 根据系统下载Node.js 下载地址:http://nodejs.cn/download 2. 安装Node.js 点击安装Node.js,在安装目录D:\Program Files\nodej ...