C语言,商品购买,商店购物,通俗易懂

商品购买,实现以下功能

1.输入商品信息,既菜单栏

2.进行购买选择

3.是否购买,然后更新

实现代码如下:

1.输入商品信息

void InsertGoods() {
	printf("请输入商品名称:");
	scanf("%s",&commodity[count].name);
	printf("请输入商品数量:");
	scanf("%d",&commodity[count].num);
	printf("请输入商品价格:");
	scanf("%f",&commodity[count].price);
	count ++;
}

2.输入购买信息

void InputCommodity() {
	printf("请输入商品名称\n");
	char tmp[10];
	scanf("%s",tmp);
	for(int i =0; i<count; i++) {
		if(strcmp(tmp,commodity[i].name)==0) {
			goods[sp].id = i;
		}
	}
	printf("请输入购买数量\n");
	scanf("%d",&goods[sp].sum);
	goods[sp].status = 0;
	if(goods[sp].sum > commodity[goods[sp].id].num) {
		printf("buy error\n");
		InputCommodity();
	}else{
		printf("输入指令\n");
	}
	sp++;
	return;
}

3.价格以高低排序

void sort() {
	for(int i=0; i<count; i++) {
		for(int j=0; j<count-1; j++) {
			if(commodity[j].price>commodity[j+1].price) {
				Commodity y = commodity[j];
				commodity[j]=commodity[j+1];
				commodity[j+1] = y;

			}
		}
	}
}

4.显示购买信息

void ShowGoods() {
	printf("%s\t%s\t%s\t%s\n","商品编号","商品名字","商品价格","商品库存");
	for(int i = 0; i< count; i++) {
		printf("%d\t\t%s\t\t%.1f\t\t%d\n",i,commodity[i].name,commodity[i].price,commodity[i].num);
	}

}

5.显示主菜单

void ShowCommodity() {
	printf("%s\t%s\t%s\t%s\t%s\n","商品编号","商品名字","商品价格","购买数量","购买单位总价");
	for(int i = 0; i< sp; i++) {
		if(goods[i].status==0)
			printf("%d\t\t%s\t\t%.1f\t\t%d\t\t%.1f\n",goods[i].id,commodity[goods[i].id].name,commodity[i].price,goods[i].sum,goods[i].sum*commodity[i].price);
	}
	printf("-----请选择功能选项------\n");
	printf("1.直接购买\n");
	printf("2.更改购买信息\n");
	printf("0.跳出购物车\n");
	while(1) {
		int n = 0;
		printf("please input section:");
		scanf("%d",&n);
		switch(n) {
			case 1:
				for(int i =0; i<sp; i++) {
					goods[i].status = 1;
					commodity[i].num -= goods[i].sum;
				}
				printf("购买成功!\n");
				return;
			case 2:
				printf("输入id:");
				int id,o;
				scanf("%d",&id);
				printf("1.不买了:\n2.再买一个"); 
				scanf("%d",&o);
				switch(o) {
					case 1:
						for(int i=0; i<sp; i++) {
							if(id==goods[i].id) {
								goods[i].status = -1;
							}
						}
						break;
					case 2:
						for(int i=0; i<sp; i++) {
							if(id==goods[i].id) {
								goods[i].sum++;
							}
						}
						break;
				}
			case 0:
				return;
		}
	}

}

6.指令选择

void title() {
	printf("输入指令:\n");
	printf("1.添加商品到购物车\n");
	printf("2.将商品按价格排序\n");
	printf("3.查看购物车\n");
	printf("4.管理员界面\n");
}

8.完整程序如下

商品购买程序

  • 5
    点赞
  • 39
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
链表是一种常见的数据结构,它由一系列的结点组成。每个结点包含两部分,即数据域和指针域。数据域用于存储具体的数据,而指针域用于指向下一个结点的地址。链表的基本操作包括插入、删除和查找。 1. 插入操作:链表的插入操作可以在链表的任意位置插入一个新的结点。首先,创建一个新的结点,并将要插入的数据存储在该结点的数据域中。然后,将该结点的指针域指向原来位置的结点,同修改前一个结点的指针域,使其指向新插入的结点。 2. 删除操作:链表的删除操作可以删除链表中的一个结点。首先,找到要删除的结点,并记录下其前一个结点的地址。然后,将前一个结点的指针域指向要删除结点的下一个结点,从而跳过要删除的结点。 3. 查找操作:链表的查找操作可以在链表中搜索指定的数据。从链表的头结点开始,依次遍历链表的每个结点,直到找到目标数据或者到达链表的末尾。 这些基本操作可以帮助我们进行链表的增删改查操作。通过合理地运用这些操作,我们可以实现各种复杂的功能。需要注意的是,在进行链表操作,我们需要确保指针的正确性,避免出现指针丢失或者指针指向错误的情况。 总之,链表是一种灵活且常用的数据结构,通过简单的插入、删除和查找操作,我们可以实现各种功能。希望以上解释对您有帮助。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [【C语言链表实现】学生成绩管理系统(功能全面,通俗易懂)](https://blog.csdn.net/weixin_72074975/article/details/130254484)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [C语言链表详解(通俗易懂,超详细)](https://blog.csdn.net/weixin_46145739/article/details/104590875)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [C语言链表详解(通俗易懂)](https://blog.csdn.net/weixin_61661271/article/details/125131994)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Devour123

愿每一份用功都可以得到回报

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值