[leetcode] 365. Water and Jug Problem

441 篇文章 0 订阅
284 篇文章 0 订阅

Description

You are given two jugs with capacities x and y litres. There is an infinite amount of water supply available. You need to determine whether it is possible to measure exactly z litres using these two jugs.

If z liters of water is measurable, you must have z liters of water contained within one or both buckets by the end.

Operations allowed:

Fill any of the jugs completely with water.
Empty any of the jugs.
Pour water from one jug into another till the other jug is completely full or the first jug itself is empty.
Example 1: (From the famous “Die Hard” example)

Input:

x = 3, y = 5, z = 4

Output:

True

Example 2:

Input:

x = 2, y = 6, z = 5

Output:

False

分析

题目的意思是:有两个容量分别为x和y升的水壶,用这两个水壶能否量出z升水。

  • 杯子,容量分别为x和y,通过用两个杯子往里倒水,和往出舀水,问能不能使容器中的水刚好为z升。可以用一个公式来表达:
z = m * x + n * y
  • 其中m,n为舀水和倒水的次数,正数表示往里舀水,负数表示往外倒水,那么题目中的例子可以写成: 4 = (-2) * 3 + 2 * 5,即3升的水罐往外倒了两次水,5升水罐往里舀了两次水。那么问题就变成了对于任意给定的x,y,z,存不存在m和n使得上面的等式成立。
  • 根据裴蜀定理,ax + by = d的解为 d = gcd(x, y),那么只要z % d == 0,上面的等式就有解,所以问题就迎刃而解了,只要看z是不是x和y的最大公约数的倍数就行了,别忘了还有个限制条件x + y >= z,因为x和y不可能称出比它们之和还多的水.

代码

class Solution {
public:
    bool canMeasureWater(int x, int y, int z) {
        return z==0||(x+y>=z&&z%gcd(x,y)==0);
    }
    int gcd(int x,int y){
        return y==0 ? x:gcd(y,x%y);
    }
};

参考文献

[LeetCode] Water and Jug Problem 水罐问题

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

农民小飞侠

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

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

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

打赏作者

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

抵扣说明:

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

余额充值