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语言作为一种计算机的语言,我们学习它,有助于我们更好的了解计算机,与计算机进行交流,因此, ...
随机推荐
- 使用反射获取类中的属性(可用于动态返回PO类的列,当做表格的表头)
//利用反射取类中的属性字段 try { Class clazz = Class.forName("houji.bean.model.TaskModel"); Field[] fi ...
- LA 并查集路径压缩
题目大意:有n个节点,初始时每个节点的父亲节点都不存在.有两种操作 I u v:把点节点u的父亲节点设为v,距离为|u-v|除以1000的余数.输入保证执行指令前u没有父亲节点. E u:询问u到根节 ...
- 封装的一个Worker方法,利用线程处理运行时间较长的js代码
function webWorker(targetFile,content){ var promise=new Promise(function(resolve,reject){ var web=ne ...
- java中执行JS脚本
package 测试包; import javax.script.*; public class SSSSSSSSS { public SSSSSSSSS() { // TODO Auto-gener ...
- python--爬取http://www.kuaidaili.com/并保存为xls
代码如下: 复制在python3上先试试吧^_^ # -*- coding: utf-8 -*- """ Created on Mon Jun 12 13:27:59 2 ...
- Python入门--9--格式化
字符串格式化符号含义 符 号 说 明 %c 格式化字符及其ASCII码 %s 格式化字符串 %d 格式化整数 %o ...
- SharedPreferences 存储数组+双击退出
public static void saveApkEnalbleArray(Context context,boolean[] booleanArray) { SharedPreferences p ...
- hanzi 全拼音 qu de
Function pinyin(ByVal mystr As String, Optional types As Byte = 0) As StringDim temp As String, i ...
- 关于MySQL存储过程异常处理的一点心得
DROP PROCEDURE IF EXISTS `SP_MODEL`; DELIMITER ;;CREATE PROCEDURE `SP_MODEL`(IN V_TYPE INT)BEGIN /** ...
- .NET Core 3.0之创建基于Consul的Configuration扩展组件
写在前面 经过前面三篇关于.NET Core Configuration的文章之后,本篇文章主要讨论如何扩展一个Configuration组件出来.如果前面三篇文章没有看到,可以点击如下地址访问 .N ...