杂题——1187: 假币问题

题目描述
居然有假币!!! 
事情是这样的,现在猪肉涨了,但是农民的工资却不见涨啊,没钱怎么买猪肉啊。老王这就去买猪肉,结果找来的零钱中有假币!!!可惜老王一不小心把它混进了一堆真币里面去了。现在知道假币的重量比真币的质量要轻。给你一个天平,请用最快的时间把那个可恶的假币找出来。

输入格式
输入有多行,每一行的值为硬币的数目n,1≤n≤2^30,输入0结束程序

输出格式
最少要称多少次一定能把那个假币找出来。输出对应输入行数.

样例输入
3
12
0
样例输出
1
3

分析:

  • 如果硬币数目为 1,则表示已找到假币,无需再进行称重。
  • 否则,我们将这些硬币分成三等份:
    • 如果总数能被 3 整除,则每份硬币数相等;
    • 如果不能整除,则其中两份数目相等,而最后一份可能比其他两份多一个硬币。
  • 将硬币分成三等份后,取相同的两份上称,然后找出重量较轻的一份硬币(即是假币所在的那一份),并继续对这一份硬币重复上述步骤,直到找到唯一的假币。
import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        
        int count = 0;
        while (true) {
            int n = scanner.nextInt();
            if (n == 0) {//退出程序
                break;
            }

            int weighings = 0;
            while (n > 1) {//n==1时,不用称就知道是假币
                weighings++;
                n = (n % 3 == 0) ? n / 3 : n / 3 + 1;
                //将硬币分成三等份,取相同的两份上称,然后对较轻的那堆继续分割
                //n%3==0表示可以分成三等份
                //n%3!=0其中两份数目相等,而最后一份可能比其他两份多一个硬币,比如8=3+3+2(最多的堆有3个)
            }
            
            System.out.println(weighings);
        }
    }
}

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

戏拈秃笔

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

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

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

打赏作者

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

抵扣说明:

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

余额充值