瓶水有毒问题

瓶水有毒问题的变型有很多:

1000瓶水有1瓶水有毒,老鼠喝一滴就会死,但是需要一月毒发,请问最少需要多少老鼠才能找到那瓶有毒的水。
1000瓶药水,1瓶有毒,老鼠毒发24h,如何用最少的老鼠在24h内找出毒药。

反正老鼠就不是立马死(老鼠:我太难了)。所以在实际可行的情况下,无法利用1只老鼠测出哪瓶水有毒。

这个时候就需要动点脑筋了。如果你了解布隆过滤器,那么这个问题对你来说,是比较轻松的事情(思路可借鉴呀)。

这道智力题,重在考察你对二进制生活中的场景的应用。

我们知道 2的10次方等于1024,1024以内的所有自然数都可以用10个数位的二进制数表示出来。1000 <= 1024。那就好办了,

我们将1000瓶水从water[0]到water[999]分别进行编号,并转化成10个数位的二进制数。

9 8 7 6 5 4 3 2 1 0 位数

0 0 0 0 0 0 0 0 0 0 对应编号0
0 0 0 0 0 0 0 0 0 1 对应编号1
1 1 1 1 1 0 0 1 1 1 对应编号999

我们将10只老鼠从mouse[0]到mouse[9]进行编号

让第mouse[0]只老鼠喝第0位为1的水
让第mouse[1]只老鼠喝第1位为1的所有的水
让第mouse[2]只老鼠喝第2位为1的所有的水
依次类推
最后可以根据老鼠的死亡情况,推算出编号n。从mouse[0]到mouse[9] 活着的老鼠对应位为0,死了的老鼠对应位为1。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值