题目原文:

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次

转载于:https://www.cnblogs.com/evasean/p/7208986.html

Coursera Algorithms week1 算法分析 练习测验: Egg drop 扔鸡蛋问题相关推荐

  1. Coursera Algorithms week3 快速排序 练习测验: Nuts and bolts

    题目原文: Nuts and bolts. A disorganized carpenter has a mixed pile of n nuts and n bolts. The goal is t ...

  2. java动态规划鸡蛋问题_教你彻底理解动态规划——扔鸡蛋问题 Drop Eggs2

    问题 有一个n层的建筑.如果一个鸡蛋从第k层及以上落下,它会碎掉.如果从低于这一层的任意层落下,都不会碎. 有m个鸡蛋,用最坏的情况下实验次数最少的方法去找到k, 返回最坏情况下所需的实验次数. 样例 ...

  3. 254. Drop Eggs (扔鸡蛋经典题)

    Drop Eggs 中文English There is a building of n floors. If an egg drops from the k th floor or above, i ...

  4. c++扔鸡蛋问题egg dropping puzzle(附完整源码)

    C++扔鸡蛋问题egg dropping puzzle 扔鸡蛋问题egg dropping puzzle算法的完整源码(定义,实现,main函数测试) 扔鸡蛋问题egg dropping puzzle ...

  5. [CareerCup] 6.5 Drop Eggs 扔鸡蛋问题

    6.5 There is a building of 100 floors. If an egg drops from the Nth floor or above, it will break. I ...

  6. Leetcode 1884. Egg Drop With 2 Eggs and N Floors [Python]

    细读example 2: One optimal strategy is: Drop the 1st egg at floor 9. If it breaks, we know f is betwee ...

  7. 课程笔记|吴恩达Coursera机器学习 Week1 笔记-机器学习基础

    1 1. Introduction 1.1 Supervised Learning 已知输入x以及其对应的标签y,求解 f:x→y 回归 regression:输出的结果y是一个连续的变量 y=ℝ 分 ...

  8. LeetCode 887. Super Egg Drop

    题目链接:https://leetcode.com/problems/super-egg-drop/ 题意:给你K个鸡蛋以及一栋N层楼的建筑,已知存在某一个楼层F(0<=F<=N),在不高 ...

  9. 算法分析入门体会1一筐鸡蛋问题

    *体会算法分析入门 * #include <iostream> using namespace std; int main() {int i, sum=1;for (i = 3; 1; i ...

最新文章

  1. C++读某个内存地址对应的值
  2. 一起谈.NET技术,保护您的 Silverlight 应用程序的安全
  3. 边工作边刷题:70天一遍leetcode: day 33-3
  4. php遍历指定目录中的内容2
  5. 利用宝塔linux面板+苹果CMS搭建电影网站(二)网站的配置+电影资源的爬取上传
  6. 公开课视频与课件(完全免费)-《大企业云桌面部署实战》
  7. Tomcat常用面试题
  8. 详解varint编码原理
  9. 数据库应用程序为什么不能脱离数据库管理系统独立运行
  10. SharePoint 2013 入门教程--系列文章
  11. python 重启电脑_如何在系统重启后恢复Python脚本?
  12. 在ISA2006以SSL-TO-HTTP方式发布内部的WEB服务器(二)
  13. skynet 学习笔记-netpack模块(1)
  14. Atitit 标签式tab 切换的实现 Softdev=declare+intercept 申明+解释 软件=代码+文档 软件=数据结构+算法 软件=程序+数据+文档 申明式 decla
  15. 64位win10系统中无法开启vmware的VT-X嵌套虚拟化功能的解决方法
  16. 中国传媒发展十大趋势
  17. 自学Java系列 笔记2 高级类特性1
  18. 山寨王被山寨 腾讯九城恶性竞争害产业
  19. 接口能通但是没有数据_直接用大脑联网刷微博看电影看小说!脑机接口最新专利详解...
  20. Eclipse显示空白符号的具体设置

热门文章

  1. 动态网页中隐藏url参数传递的方法
  2. Python notes
  3. 别太把GitHub的Star当回事
  4. 一条简单的 SQL 执行超过1000ms,纳尼?
  5. Redlock:Redis分布式锁最牛逼的实现
  6. Spring Boot 缓存开发实战
  7. Javascript继承机制的设计思想
  8. jQuery-全选、全不选、反选、提交等功能的实现(试了你就知道)
  9. wordpress怎么打开php网站,wordpress怎么做网站
  10. android api接口封装,生成App接口