杂题——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. ——1187: 假币问题

    2024-03-19 23:00:05       24 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-03-19 23:00:05       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-03-19 23:00:05       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-03-19 23:00:05       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-03-19 23:00:05       20 阅读

热门阅读

  1. js iframe获取documen中的对象为空问题

    2024-03-19 23:00:05       18 阅读
  2. 计算机网络技术基础知识

    2024-03-19 23:00:05       21 阅读
  3. el-input添加keyup事件无响应

    2024-03-19 23:00:05       18 阅读
  4. 掘根宝典之c++标识符,命名

    2024-03-19 23:00:05       21 阅读
  5. 爬虫基本原理实现以及问题解决

    2024-03-19 23:00:05       21 阅读