The recovery time complexity of a coin weighing algorithm

Hanxuan Wang
DOI: https://doi.org/10.54254/2753-8818/30/20241106
2024-01-24
Abstract:Given n identical-looking coins each with possible weight in {0, 1}, and a scale that can measure the weight of any arbitrary set of coins, the coin weighing problem studies how to find out the weight of every coin with as few weighing as possible. The algorithm in Lindstrm takes O(n/logn) non-adaptive weighings to determine the coins, which gives an O(logn) factor improvement compared with the nave algorithm that measures each coin on its own. However, it is unclear that with the O(n/logn) queries, how long it takes to retrieve x. This paper is about establishing and further optimizing the nave recovery time complexity of Lindstrm s algorithm. The recovery time complexity here is defined as the time complexity to recover x given Dx under the RAM model, where D{0,1}^(mn),, each row being a weighing query, is the Lindstrm query matrix. The brute force recovery algorithm has running time O(m2n), whereas our algorithm only takes O(mn). Finally, we run experiments to verify our results with the actual running time of the algorithm on various size of inputs
What problem does this paper attempt to address?