leetCode 1518. 换水问题

1518. 换水问题

题解: java 对数学中除法和取模的运用 注释清晰

原题描述

超市正在促销,你可以用 numExchange 个空水瓶从超市兑换一瓶水。最开始,你一共购入了 numBottles 瓶水。

如果喝掉了水瓶中的水,那么水瓶就会变成空的。

给你两个整数 numBottles 和 numExchange ,返回你 最多 可以喝到多少瓶水。

示例1
输入:numBottles = 9, numExchange = 3
输出:13
解释:你可以用 3 个空瓶兑换 1 瓶水。
所以最多能喝到 9 + 3 + 1 = 13 瓶水。
示例2
输入:numBottles = 15, numExchange = 4
输出:19
解释:你可以用 4 个空瓶兑换 1 瓶水。
所以最多能喝到 15 + 3 + 1 = 19 瓶水。
思路

对数学中除法和取模的运用,使用除法(/)可以计算当前水瓶可以兑换多少瓶水,取模(%)计算不满足numExchange的水瓶。

解题方法
  1. 计算可以兑换水的数量。

sum+=numBottles/numExchange;
  1. 计算兑换水之后空瓶的数量。

//计算剩下空瓶数量 numBottles/numExchange 兑换水的数量,
//会转换为空瓶,numBottles%numExchange是不满足兑换1瓶水的空瓶数量
 numBottles=numBottles/numExchange+numBottles%numExchange;
  1. 只要剩下的空瓶还能兑换水,就进行循环,直到不能兑换为止。

 //初始有numBottles瓶水
 int sum=numBottles;
 //剩下水瓶可以兑换至少一瓶水,产生一个新的空瓶
 while (numBottles>=numExchange){
    //累计可以获得水的数量
    sum+=numBottles/numExchange;
    //计算剩下空瓶数量 numBottles/numExchange 兑换水的数量,
    //会转换为空瓶,numBottles%numExchange是不满足兑换1瓶水的空瓶数量
     numBottles=numBottles/numExchange+numBottles%numExchange;
}
Code
class Solution {
    public  int numWaterBottles(int numBottles, int numExchange) {
         //初始有numBottles瓶水
         int sum=numBottles;
        //剩下水瓶可以兑换至少一瓶水,产生一个新的空瓶
        while (numBottles>=numExchange){
         //累计可以获得水的数量
         sum+=numBottles/numExchange;
          //计算剩下空瓶数量 numBottles/numExchange 兑换水的数量,
          //会转换为空瓶,numBottles%numExchange是不满足兑换1瓶水的空瓶数量
        numBottles=numBottles/numExchange+numBottles%numExchange;
        }
        //返回计算累计兑换水的数量
        return sum;
    }
}
执行效果

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值