面试题:信息论之可怜的小白鼠分析

感谢陈立人http://weibo.com/lirenchen?topnav=1&wvr=5&topsug=1的每天一道面试题的资料整理。关注“待字闺中”的微信,里面有题目的分析。我会post他整理的题目,供大家一起学习。

原题:

有11瓶酒,只有一瓶有毒。喝酒之后,三天会死,只有三天时间。请问至少需要多少只老鼠,可以找出9瓶没有毒的酒。

分析:

看到这个题目,首先要对题目进行分析。题目写着只有3天时间,所以就证明只能测1次。因为我看过有题目是说7个星期,那样子的话,方法是完全不同的。因为可以是第一天喝这瓶酒,第二天喝另外一瓶酒。思路完全不同。

其次,就是说题目有11瓶酒,1瓶毒酒,但我们只要找出9瓶就可以,而不是说把毒酒找出。这里又是一个提示。不能忽略掉这里。

言归正传,这能只测1次,所以要合理分配。这时候就要想起信息论里面的二进制编码。我们对11个数进行二进制编码:

十进制数 二进制码
1 0001
2 0010
3 0011
4 0100
5 0101
6 0110
7 0111
8 1000
9 1001
10 1010
11 1011

这时候,可以看见二进制数都是0和1的位,那我们应该如何分组呢?

这时,我们看到,把在同一位置位数为1的分到一组,如分组(1,3,5,7,9,11),(2,3,6,7,10,11),(4,5,6,7),(8,9,10,11)这四组。

当三天后,某一组的有老鼠死了,就能断定是那个位数的二进制数为1。如果没有就能判定那个为0.

现在用3只老师分别判定了位数第1到第3的位数是否为1还是0,。

这时,对于第四位的判定,我们就要通过分析,

01情况 解释
000 三只老鼠都没写,只有1000这种情况,所以瓶8有毒
001 就有1001或者0001,
010 就有1010或者0010,
011 就有1011或者0011
100 只有0100,所以瓶4有毒
101 只有0101,所以瓶5有毒
110 只有0110,所以瓶6有毒
111 只有0111,所以瓶7有毒

根据这样分析,只要3只老鼠就能测试出结果。

推广,加入有1W瓶酒,又需要多少只老鼠呢?可以用同样的方法进行分析。

你可能感兴趣的:(面试,信息论)