问题I:
有1000桶酒,其中1桶有毒。而一旦吃了,毒性会在1周后发作。现在我们用小老鼠做实验,要在1周内找出那桶毒酒,问最少需要多少老鼠。
这是老鼠与毒酒最经典问法。
分析:
此问题可以用二进制的思想来解答。
将1000桶酒编号为0,1,...,999。
用10只老鼠分别负责二进制中的相应位,即
第1只老鼠,喝掉编号的二进制表示中右边第一位为1的桶内的酒,即1,3,5,7,。。。,999桶内的酒。
第2只老鼠,喝掉编号的二进制表示中右边第二位为1的桶内的酒,即2,3,6,....桶内的酒。
第3值老鼠,。。。
。。。
一周之后,哪只老鼠死了,就说明对应的二进制上的值为1。
假如,第2,5,7只老鼠死掉了,那么说明编号为0001010010,即编号为82的桶内为毒酒。
扩展一下,如果有N桶酒,只有1桶有毒,那么至少需要m只老鼠,这里m为满足2^m>=N的最小的数。
问题II:
@陈利人:有11瓶酒,只有1瓶有毒。喝酒之后,三天会死,只有三天时间。请问至少需要多少只老鼠,可以找出9瓶没有毒的酒。
分析:
按照问题I的分析,11瓶酒,需要4只老鼠可以确定出10瓶没有毒的酒(原因:2^4 > 11, 2^3 < 11)。
但是,这里只需找出9瓶没有毒的酒,不需要把10瓶都找出来。
其实,只用找出哪两瓶中肯定有毒,剩下的9瓶酒就肯定没毒。
所以,可以11瓶酒进行分组,每组两瓶酒,可分为6组:(1,2), (3,4), (5,6), (7,8), (9,10), (11)。
按照问题I的解法,对组进行编号:0,1,...,5。
那么只需要3只老鼠(2^3 > 6),就可以确定出那一组内有毒酒,那么剩下的9瓶(或者10瓶)没毒的酒就找出来了。
ps:如果是12瓶酒,要找出9瓶没毒的酒,就可以3瓶为1组,分为4组,那么就只需要2只老鼠就可以了。
问题III:
有100只一模一样的瓶子,编号1-100。其中99瓶是水,一瓶是看起来像水的毒药。只要老鼠喝下一小口毒药,一天后则死亡。现在,给你2天的时间,请你告诉我,你至少需要多少只老鼠,才能检验出哪个号码瓶子里是毒药?
此题,就成了三进制问题了。具体分析可参考博文:致被毒死的老鼠君