Water and Jug Problem
来源:互联网 发布:淘宝买恒压阀 编辑:程序博客网 时间:2024/05/17 23:08
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
解法:
纯数学题
The basic idea is to use the property of Bézout’s identity and check if z is a multiple of GCD(x, y)
Quote from wiki:
Bézout’s identity (also called Bézout’s lemma) is a theorem in the elementary theory of numbers:
let a and b be nonzero integers and let d be their greatest common divisor. Then there exist integers x
and y such that ax+by=d
In addition, the greatest common divisor d is the smallest positive integer that can be written as ax + by
every integer of the form ax + by is a multiple of the greatest common divisor d.
If a or b is negative this means we are emptying a jug of x or y gallons respectively.
Similarly if a or b is positive this means we are filling a jug of x or y gallons respectively.
x = 4, y = 6, z = 8.
GCD(4, 6) = 2
8 is multiple of 2
so this input is valid and we have:
-1 * 4 + 6 * 2 = 8
In this case, there is a solution obtained by filling the 6 gallon jug twice and emptying the 4 gallon jug once. (Solution. Fill the 6 gallon jug and empty 4 gallons to the 4 gallon jug. Empty the 4 gallon jug. Now empty the remaining two gallons from the 6 gallon jug to the 4 gallon jug. Next refill the 6 gallon jug. This gives 8 gallons in the end)
- Water and Jug Problem
- Water and Jug Problem
- Water and Jug Problem
- Water and Jug Problem
- 365. Water and Jug Problem
- 【Leetcode】Water and Jug Problem
- leetcode:Water and Jug Problem
- leetcode365. Water and Jug Problem
- 365. Water and Jug Problem
- 365. Water and Jug Problem
- leetcode---Water and Jug Problem
- 365. Water and Jug Problem
- 365. Water and Jug Problem
- 365. Water and Jug Problem
- 365. Water and Jug Problem
- 365. Water and Jug Problem
- 365. Water and Jug Problem
- [LeetCode] Water and Jug Problem
- Jquery李炎恢——23,24,25动画效果
- Windows下基于mingw的mex开发
- 帕秋莉·诺蕾姬 (Standard IO)
- C语言知识点2
- 【HDU 1325 Is It A Tree?】
- Water and Jug Problem
- 求两个子数组最大的累加和
- 【转】Java SwingWorker(三)
- 【NOIP2016提高A组模拟8.14】疯狂的火神
- Eclipse中使用google代码风格formatter
- C语言知识点3
- Android广播——监听系统状态
- C语言知识点4
- 01 快学scala第一章习题答案