题目描述
居然有假币!!!
事情是这样的,现在猪肉涨了,但是农民的工资却不见涨啊,没钱怎么买猪肉啊。老王这就去买猪肉,结果找来的零钱中有假币!!!可惜老王一不小心把它混进了一堆真币里面去了。现在知道假币的重量比真币的质量要轻。给你一个天平,请用最快的时间把那个可恶的假币找出来。输入格式
输入有多行,每一行的值为硬币的数目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);
}
}
}