LeetCode1518 换水问题

题目描述

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

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

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

示例 1:

LeetCode1518 换水问题_第1张图片

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

示例 2:

LeetCode1518 换水问题_第2张图片

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

提示:

  • 1 <= numBottles <= 100
  • 2 <= numExchange <= 100

实现思路

        每喝完numExchange瓶水便换一瓶水,那么所喝总数加1,瓶数减numExchange,直到剩下的瓶子小于numExchage,不能再换水。

实现代码

 

class Solution {
    public int numWaterBottles(int numBottles, int numExchange) {
        int bottles = numBottles;
        int result = numBottles;
        while(bottles >= numExchange){
            result++;
            bottles -= numExchange;
            bottles++;            
        }
        return result;
    }
}

你可能感兴趣的:(算法,java,数据结构)