LeetCode 1518 换酒问题

空瓶换酒问题算法
本文介绍了两种解决空瓶换酒问题的有效算法:一种是一般解法,通过循环计算直至无法继续兑换为止;另一种则是利用数学公式直接求解。两种方法都详细阐述了如何根据已有的酒瓶数量和兑换规则来确定总共能喝到多少瓶酒。

一般解法

class Solution:
    def numWaterBottles(self, numBottles: int, numExchange: int) -> int:
        # res表示最终我们能换到酒的数量
        res = numBottles
        if numBottles < numExchange:
            return res
        while numBottles >= numExchange:
            # last_blank表示换完之后剩余瓶子的数量
            last_blank = numBottles % numExchange
            # 新换的酒的数量
            new_bottle = numBottles // numExchange
            res += new_bottle
            numBottles = last_blank + new_bottle
            # 直到不能满足换酒条件终止
        return res

2第二种解法

直接考虑终止条件,即b-n(e-1)>=e,其中e-1表示实际换酒需要的空瓶个数

直接可以推出求解n的公式e\leq \frac{b-e}{e-1}+1,其中b>=e,所以需要加一

def numWaterBottles(numBottles, numExchange):
    return (numBottles - numExchange) // (numExchange - 1) + 1 + numBottles if numBottles >= numExchange else numBottles

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

hewesH

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值