•       使用动态链表完成一个简单的商品库存信息管理系统。

•       商品信息包括如下字段:商品号、商品名称、商品库存

•       函数

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)的更多相关文章

  1. XMU C语言程序设计实践(1)

    题目: 任务1:英雄出世 炎热的夏天午后,小明正在百无聊赖地写c语言程序.忽然,电脑屏幕一阵抖动,浮现下面18×18个看似杂乱无章的数字: 32,  32,  32,  32,  32,  32,  ...

  2. XMU C语言程序设计实践(4)

    以下实验二选一. 1.使用队列实现迷宫算法,找到最短路径. 2.实现顺序队列和链队列的所有基本操作,InitQueue(&Q):DestroyQueue(&Q):ClearQueue( ...

  3. XMU C语言程序设计实践(3)

    问题描述: 以一个n的长方阵表示迷宫,0和1分别表示迷宫中的通路和障碍,设计一个程序,对任意设定的迷宫,求出一条从入口到出口的通路,或得出没有通路的结论. 对于本问题需用栈实现“穷举求解”算法,即:从 ...

  4. XMU C语言程序设计实践(2)

    任务一:颠倒的世界 小明最近突然喜欢倒着写字,写出来的句子全是颠倒的,也就是把一句话里的字符全都逆序写,譬如“I Love This Game!”,他就偏偏要写成“!emaG sihT evoL I” ...

  5. 第二章 C语言编程实践

    上章回顾 宏定义特点和注意细节 条件编译特点和主要用处 文件包含的路径查询规则 C语言扩展宏定义的用法 第二章 第二章 C语言编程实践 C语言编程实践 预习检查 异或的运算符是什么 宏定义最主要的特点 ...

  6. C语言程序设计课程总结

    第一次教授C语言程序设计课程,相比计算机组成原理.arm体系结构等偏向硬件的课程,C的教学方式要灵活一些.计算机组成原理课程偏向理论,哈尔滨工业大学的计算机组成原理是国家精品课,增加了mooc+spo ...

  7. 【任务】Python语言程序设计.MOOC学习

    [博客导航] [Python导航] 任务 18年11月29日开始,通过9周时间跨度,投入约50小时时间,在19年1月25日之前,完成中国大学MOOC平台上的<Python语言程序设计>课程 ...

  8. 2019年春季学期《C语言程序设计II》助教注意事项

    本学期<C语言程序设计II>课程安排 理论课时24(1-12周),实验课时8(13周),课程设计课时16(14-15周) 理论课教学内容 附:教学进度表 本学期实验课和课程设计参考教材 & ...

  9. C语言程序设计实习报告

    C语言程序设计实习报告 简介 语言实践心得体会范文在科技高度发展的今天,计算机在人们之中的作用越来越突出.而c语言作为一种计算机的语言,我们学习它,有助于我们更好的了解计算机,与计算机进行交流,因此, ...

随机推荐

  1. BZOJ 3566 [SHOI2014]概率充电器 ——期望DP

    期望DP. 补集转化,考虑不能被点亮的情况, 然后就是三种情况,自己不能亮,父亲不能点亮它,儿子不能点亮它. 第一次计算比较容易,第二次计算的时候需要出去第一次的影响,因为一条线只能传导一次 #inc ...

  2. 雅礼培训 Problem A 【线段树】

    题意 维护一段区间,支持求区间最大值,区间且,区间或 \(n,q<=2*10^5\) 题解 我们用线段树维护区间最大值 对于and和or运算, and实质就是强行把一些位改为0 or实质就是强行 ...

  3. Bzoj2007 [Noi2010]海拔(平面图最短路)

    2007: [Noi2010]海拔 Time Limit: 20 Sec  Memory Limit: 552 MBSubmit: 2742  Solved: 1318[Submit][Status] ...

  4. 开始学习Objective-C

        加油!     顺便试试这MarsEdit好用不~

  5. Laravel 之文件上传

    配置文件: config/filesystems.php, 新建存储空间 'uplaods' => [ 'driver' => 'local', 'root' => storage_ ...

  6. Android UI自定义Spinner下拉框(用popuwindow实现)-转

    定义出第一个图片的布局和弹出框(一个listView)的布局,,这里就不在多说了~ListView需要自己定义一个MyspinnerAdapter~做好这些准备之后,就是弹出框的实现了~  prote ...

  7. ViewPager 无限循环遇到的坑 viewpager.setOffscreenPageLimit(2);

    viewpager.setOffscreenPageLimit(limit);这个方法,是表示viewpage除了当前显示的页面外,左右个预加载的页面个数,也就是 为limit=2时表示当前一共加载了 ...

  8. Mecanim动画编辑器 - 加入动画层实现并行动作

    1.创建新的状态层 a) 通过下图的1button创建一个新的层   b) 通过下图2属性设置图层的权重.假设为0,则该图层的状态不会影响到总的状态机  c) Mask是设置动画的Avatar的关联节 ...

  9. 转: 工欲善其事,必先利其器系列--Netbeans之远程开发

    转自: http://www.cnblogs.com/zuoca/archive/2012/07/09/Remote_Development_With_Netbeans_origin.html 工欲善 ...

  10. centos 複製時顯示進度的指令 pv

    Pipe Viewer 的简称pv:意思是通过管道显示数据处理进度的信息.这些信息包括已经耗费的时间,完成的百分比(通过进度条显示),当前的速度,全部传输的数据,以及估计剩余的时间. yum inst ...