Here is the problem:
You have n coins where n = 2^k for an integer k such that n − 2 coins are of the same weight and two coins weigh more than others. Two heavier coins may be of the same weight, or their weights may be different. You have a balance scale: you can put any number of coins on each side of the scale at one time, and it will tell you if the two sides weigh the same, or which side is lighter if they do not weigh the same. Outline an algorithm for finding the two heavier coins using O(log n) weighings.
I know the answer if there is only one coin that is different than others. And I also found similar question where the different coins are known to be heavier.
Given n coins, some of which are heavier, find the number of heavy coins?
Any help.
Suppose you split the coins into two piles of 2k-1 coins.
Now, for the proof of the number of weighings.
Assuming we never use the "one heavy coin solution", this setup will in the worst-case take two weighings to cut the search space in half. Thus, the number of weighings here is 2 log n
.
Note that we use the "one heavier coin solution" at most twice. Thus, a loose upper bound is 2 log n
from the above two steps, plus 2 times the number of weighings for the "one heavier coin solution", which gets us 2 log n + 2 * O(log n)
, which is still O(log n)
.