喝汽水问题,1瓶汽水1元,2个空瓶可以换一瓶汽水,给20元,可以喝多少汽水

文章讲述了如何通过编程实现一个经济学问题,即给定一定金额和空瓶换汽水规则,计算能喝到的最多汽水数量。使用while循环模拟兑换过程,直到无法再兑换为止。
摘要由CSDN通过智能技术生成

【问题描述】
喝汽水,1瓶汽水1元,2个空瓶可以换一瓶汽水,给20元,可以喝多少汽水(编程实现)。
【解题思路】
变量解释:money总金额数,price汽水单价,exchange几个空瓶可以换一瓶汽水。
total可以喝到的总瓶数,empty空瓶数。

有money元钱,一共可以喝到total = money / price瓶汽水。
喝完后剩余empty = total个空瓶子。
可以兑换( empty / exchange)瓶新的汽水,剩余( empty%exchange)个空瓶子,不足兑换一瓶新的汽水。
新兑换的汽水喝完后又会有( empty / exchange)个空瓶子剩余, 所以目前剩余空瓶子为:empty = empty / exchange + empty%exchange 个空瓶子。
以此循环,直到剩余的瓶子(empty%exchange)不足以兑换一瓶新的汽水结束。
【本题中】

20元钱,可以喝到20瓶水,
剩余20个空瓶子,可以兑换20/2 = 10瓶汽水,兑换之后剩余20%2 = 0个空瓶子。这时一共可以喝到:20+10 = 30瓶水。
剩余空瓶子10 + 0 = 10个,可以兑换10/2=5瓶水,兑换之后剩余10%2 = 0个空瓶子。这时一共可以喝到:30+5 = 35瓶水。
剩余空瓶子5 + 0 = 5个,可以兑换5/2=2瓶水,兑换之后剩余5%2 = 1个空瓶子。这时一共可以喝到:35+2 = 37瓶水。
剩余空瓶子2 + 1 = 3个,可以兑换3/2=1瓶水,兑换之后剩余3%2 = 1个空瓶子。这时一共可以喝到:37+1 = 38瓶水。
剩余空瓶子1 + 1 = 2个,可以兑换2/2=1瓶水,兑换之后剩余2%2 = 0个空瓶子。这时一共可以喝到:38+1 = 39瓶水。
此时剩余空瓶子1+0=1个,不足以兑换一瓶新汽水,循环结束。一共可以喝到39瓶汽水。
注意:剩余空瓶子为:上次兑换的新的汽水喝完后留下的空瓶子+兑换之后剩余不足以兑换新汽水的空瓶子。

【代码】

本代码实现了不定金额数,不定汽水单价,不定几个空瓶可以兑换一瓶汽水的情况。代码的适应性较强。

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
int main()
{
	int money = 0;
	printf("总共有多少钱:");
	scanf("%d", &money);

	int price = 0;
	printf("每瓶汽水单价为:");
	scanf("%d", &price);

	int exchange = 0;
	printf("多少个空瓶可以换一瓶水");
	scanf("%d", &exchange);

	int tatol = 0;//总共可以喝多少瓶汽水
	int empty = 0;//空瓶子数量

	tatol = money / price;
	empty = tatol;
	
	while (empty >= exchange)
	{
		tatol = tatol + empty / exchange;//20+10 //30+5 //35+2 //37+1 //38+1
		empty = empty / exchange + empty % exchange;//10 //5 //2+1 //1+1 //1
	}
	printf("一共可以喝到%d瓶汽水", tatol);

}

  • 10
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQLAlchemy 是一个 SQL 工具包和对象关系映射(ORM)库,用于 Python 编程语言。它提供了一个高级的 SQL 工具和对象关系映射工具,允许开发者以 Python 类和对象的形式操作数据库,而无需编写大量的 SQL 语句。SQLAlchemy 建立在 DBAPI 之上,支持多种数据库后端,如 SQLite, MySQL, PostgreSQL 等。 SQLAlchemy 的核心功能: 对象关系映射(ORM): SQLAlchemy 允许开发者使用 Python 类来表示数据库表,使用类的实例表示表中的行。 开发者可以定义类之间的关系(如一对多、多对多),SQLAlchemy 会自动处理这些关系在数据库中的映射。 通过 ORM,开发者可以像操作 Python 对象一样操作数据库,这大大简化了数据库操作的复杂性。 表达式语言: SQLAlchemy 提供了一个丰富的 SQL 表达式语言,允许开发者以 Python 表达式的方式编写复杂的 SQL 查询。 表达式语言提供了对 SQL 语句的灵活控制,同时保持了代码的可读性和可维护性。 数据库引擎和连接池: SQLAlchemy 支持多种数据库后端,并且为每种后端提供了对应的数据库引擎。 它还提供了连接池管理功能,以优化数据库连接的创建、使用和释放。 会话管理: SQLAlchemy 使用会话(Session)来管理对象的持久化状态。 会话提供了一个工作单(unit of work)和身份映射(identity map)的概念,使得对象的状态管理和查询更加高效。 事件系统: SQLAlchemy 提供了一个事件系统,允许开发者在 ORM 的各个生命周期阶段插入自定义的钩子函数。 这使得开发者可以在对象加载、修改、删除等操作时执行额外的逻辑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值