倒水问题-->经典面试题目

题目详细:

有两个容器,容积分别为A升和B升,有无限多的水,现在需要C升水。
我们还有一个足够大的水缸,足够容纳C升水。起初它是空的,我们只能往水缸里倒入水,而不能倒出。
可以进行的操作是:
把一个容器灌满;
把一个容器清空(容器里剩余的水全部倒掉,或者倒入水缸);
用一个容器的水倒入另外一个容器,直到倒出水的容器空或者倒入水的容器满。

问是否能够通过有限次操作,使得水缸最后恰好有C升水。
 
输入:三个整数A, B, C,其中 0 < A , B, C <= 1000000000
输出:0或1,表示能否达到要求。

算法:

实际上这个就是扩展的欧几里得算法,代码上照搬就可以了。

  定理:对于不完全为 0 的非负整数 a,b,gcd(a,b)表示 a,b 的最大公约数,必然存在整数对 x,y ,使得 gcd(a,b)=ax+by。

  也就是说, A和B辗转相除取得最大公约数D后, D是可以由A和B倒水得出来的。如果D为C的约数,则一定可以达到要求。

代码:

 1 public class PourWater {
 2     private static int can(int a, int b, int c) {
 3         int res = mod(a, b);
 4         if (c % res == 0) {
 5             return 1;
 6         } else {
 7             return 0;
 8         }
 9     }
10     
11     private static int mod(int a, int b) {
12         if (a % b == 0) {
13             return b;
14         } else {
15             return mod(b, a % b);
16         }
17     }
18     
19     public static void main(String[] args) {
20         // TODO Auto-generated method stub
21         System.out.println(can(3, 5, 4));
22     }
23 }

 

转载于:https://www.cnblogs.com/lone-wolf/p/4233632.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值