题目原文:

Suppose that you have an n-story building (with floors 1 through n) and plenty of eggs. An egg breaks if it is dropped from floor T or higher and does not break otherwise. Your goal is to devise a strategy to determine the value of T given the following limitations on the number of eggs and tosses:

  • Version 0: 1 egg, ≤T tosses.
  • Version 1: ∼1lgn eggs and ∼1lgn tosses.
  • Version 2: ∼lgT eggs and ∼2lgT tosses.
  • Version 3: 2 eggs and ∼2$ \sqrt{n} $ tosses.
  • Version 4: 2 eggs and ≤c$ \sqrt{T} $ tosses for some fixed constant c

分析:

version0 : 拿着一个鸡蛋从1~n依次扔就可以,到floor T会碎,故复杂度为≤T

version 1:  采用二分查找,首先从n/2层开始扔:

      if(鸡蛋碎) 从(n/2)/2层开始扔;

      else 从n/2+(n/2)/2层开始扔

     二分方法需要lgn个鸡蛋尝试lgn次

version 2: 依次从1, 2, 4, 8, 16, 32,...2k开始扔,如果鸡蛋在2k碎了,那么2k-1≤T≤2k,这时已经使用了 lgT 次步,接下来在[2k-1+1,2k)区间进行version1的二分查找方法,需要花费lgT步。这两种操作加起来总共花费2lgT步

version 3: 将0~n层楼分成[1, $ \sqrt{n} $-1], [$ \sqrt{n} $, 2 $ \sqrt{n} $-1], [2$ \sqrt{n} $,3 $ \sqrt{n} $-1]...[k$ \sqrt{n} $, (k+1)$ \sqrt{n} $-1]..个区间,用一个鸡蛋分布从1开始在各个区间的起始楼层扔,如果在k$ \sqrt{n} $层碎了,那就从(k-1)$ \sqrt{n} $+1开始逐层扔。第一步区间选择用了 $ \sqrt{n} $的复杂度,第二步区间内部扔鸡蛋用了 $ \sqrt{n} $的复杂度,总共用了 2$ \sqrt{n} $

version 4: 尝试从1, 4, 9, 16, 25,...(k-1)2, k2....楼层扔鸡蛋,加入鸡蛋在楼层k2碎了,意味着(k-1)2≤T≤k2,这一步尝试了$ \sqrt{T} $次(k=$ \sqrt{T} $)。接着从楼层(k-1)2+1开始逐层扔,最多尝试至k2-1结束,这一步需要尝试k2-1-(k-1)2-1=2$ \sqrt{T} $-1=2$ \sqrt{T} $-2次。总共用了3$ \sqrt{T} $-2次

最新文章

  1. 理解 Neutron FWaaS - 每天5分钟玩转 OpenStack(117)
  2. 解决在web项目使用log4j中无法将log信息写入文件
  3. 微信JS SDK PHP Demo
  4. 求助 WPF ListViewItem样式问题
  5. 关于put 上传图片的解决方式
  6. linux sar 命令详解
  7. php+mysql非缓冲查询(如何循环大数组)
  8. cocos2d-x创建新项目模板
  9. Winform_devexpress开发框架主界面设计
  10. iOS的settings bundle中开关按钮(Toggle Switch)取不到值的问题
  11. 使用 pm2 守护你的 .NET Core 应用程序
  12. 同源策略jsonp和cors
  13. 两种方法:VS2008下C++窗体程序显示控制台的方法——在QT程序中使用cout和cin
  14. PLA-1
  15. Codeforces 633F The Chocolate Spree 树形dp
  16. splinter
  17. oracle_效率优化
  18. ionic1项目中 ion-slide轮播用ng-repeat遍历数据后自动循环出问题
  19. 解题:HAOI 2015 按位或
  20. ios开发之--判断奇偶数

热门文章

  1. 常用的SSH注解标签
  2. dubbo之主机绑定
  3. 如何在eclipse中设置断点并调试程序
  4. Notepad++运行JAVA代码
  5. 字符串问题:去掉字符串中连续出现 k 个 0 的子串
  6. (C/C++学习)13.C语言字符串处理函数(一)
  7. Linux之iptables(四、网络防火墙及NAT)
  8. 使用PHP操作MongoDB数据库
  9. 1. Python中的基本数据类型、运算、变量
  10. 第七节:pandas排序