100层楼2个鸡蛋求最低破碎楼层与信息论

100层楼2个鸡蛋求最低破碎楼层经典算法可以参考  http://blog.sina.com.cn/s/blog_6c813dbd0101bh98.html

这篇文档我们从更高的视角-信息论的角度去看这个问题

对于 100 层楼,假设1楼不会碎,100层楼中必定有一层会碎,那么则共有 99 种可能。

对于两个鸡蛋,假设共有 m 个动作,这个 m 个动作里面,可能有 0、 1 或 2 个动作鸡蛋会碎。那么 m 个动作,便有 1 + m + m(m-1)/2 种可能。也就说 当 1 + m + m(m-1)/2 < 99 时,我们是绝对没有任何可能去求出最低破碎楼层的。

根据以上,我们可以得出 m >= 14,也就是说从信息论角度上,14次是理论上的最优解。

那么,接下来,我们就要想出一个方法去达到这个最优解。

其实,这个也简单,我们只要从信息论角度去反推即可。

首先考虑 14 次动作里面,假设第一个鸡蛋是 m 次动作碎的,那么第二个鸡蛋便只能是 m+1 ~ 14 次动作里面碎或者不碎,也就是说第一个鸡蛋碎了之后,第二个鸡蛋便最多携带 14 - m 个信息。由此我们很容易得出一个 1,2,3,..,13,14 的的队列,自然也就容易想到第一个鸡蛋尝试的楼层间的间隔依次是 1,2,3,..,13,14 了。

  • 0
    点赞
  • 0
    收藏
  • 打赏
    打赏
  • 7
    评论

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

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
©️2022 CSDN 皮肤主题:大白 设计师:CSDN官方博客 返回首页
评论 7

打赏作者

buyulian

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值