一开始看不同的version描述很费解,后来看了evasean 的解释豁然开朗,都是类似于二分法的思想。或许升级可以问最少用多少个鸡蛋,扔几次之类的。

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: ∼lgn eggs and ∼lgn tosses.
Version 2: ∼lgT eggs and ∼2lgT tosses.
Version 3: 2 eggs and ∼2sqrt(n) tosses.
Version 4: 2 eggs and ≤csqrt(T) tosses for some fixed constant c

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

version 1: 采用二分查找,首先从n/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, n‾√-1], [n‾√, 2 n‾√-1], [2n‾√,3 n‾√-1]…[kn‾√, (k+1)n‾√-1]..个区间,用一个鸡蛋分布从1开始在各个区间的起始楼层扔,如果在kn‾√层碎了,那就从(k-1)n‾√+1开始逐层扔。第一步区间选择用了 n‾√的复杂度,第二步区间内部扔鸡蛋用了 n‾√的复杂度,总共用了 2n‾√

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

EggDrop Problem(扔鸡蛋问题)相关推荐

  1. dp 扔鸡蛋_使用动态编程(DP)的鸡蛋掉落问题

    dp 扔鸡蛋 Problem statement: You are given N floor and K eggs. You have to minimize the number of times ...

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

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

  3. 总结 扔鸡蛋问题——1

    前言 最近我在知乎上看到了一个扔鸡蛋的问题[1],问题描述如下.在网上学习后,将相关知识整理如下. 正文 问题 有一个 n 层的建筑.如果一个鸡蛋从第 k 层及以上落下,它会碎掉.如果从低于这一层的任 ...

  4. 谷歌面试 扔鸡蛋_如何解决Google招聘人员关于从建筑物中扔鸡蛋的难题

    谷歌面试 扔鸡蛋 by Marcin Moskala 通过Marcin Moskala 如何解决Google招聘人员关于从建筑物中扔鸡蛋的难题 (How to solve the Google rec ...

  5. 扔鸡蛋问题-动态规划

    这个问题是一个印度朋友问我的. 已知有e个鸡蛋,f层楼.问题是尽可能少的尝试,找出扔出鸡蛋不破的最高的楼层. 最开始我的思路是,如果只有一个鸡蛋,f层楼,毫无疑问,只能从一楼到二楼到三楼...依次尝试 ...

  6. 高楼扔鸡蛋——动态规划问题

    今天算法课大伙做了一份课堂测验,是有关一维以及二维动态规划问题的,其中最后一天压轴的就是这道高楼扔鸡蛋问题. 在我得意洋洋以为能早早做完这份测验然后交卷的时候,我在这道题上摁是扣了半小时头皮,也没写出 ...

  7. Coursera Algorithms week1 算法分析 练习测验: Egg drop 扔鸡蛋问题

    题目原文: Suppose that you have an n-story building (with floors 1 through n) and plenty of eggs. An egg ...

  8. 抛鸡蛋html5游戏,数学智力题:扔鸡蛋计算不会碎的楼层

    智力题涵盖数学天地.侦探谜题.逻辑思维.猜谜大全.趣味益智.图形视觉等等.你知道有哪些经典智力题吗?下面小编为你整理经典数学智力题,希望能帮到你. 数学智力题:扔鸡蛋计算不会碎的楼层 扔鸡蛋计算不会碎 ...

  9. 经典谷歌面试题-扔鸡蛋问题

    假如有100层楼,总共有2个鸡蛋.需要多少次才能试探出临界点,比如,在第三层扔下去,不碎:在第四层扔下去,碎了,那第三层和第四层就是临界点.  如果之前没准备过的话,大概第一个想到的就是二分法. 1. ...

最新文章

  1. incompatible with sql_mode=only_full_group_by
  2. 如何在计算机配置里面设置隐藏c盘,玩转电脑组策略(指定运行程序/隐藏C盘)
  3. 浅谈用户体验的 4 个维度
  4. python定时播放音乐程序_python实现闹钟定时播放音乐功能
  5. idea启动日志在哪里_牛逼了!用 IDEA 扒出了开源组件导致FGC的原因
  6. html360度视角观赏,360度全景图是如何生成的?
  7. 【转】写给想学习自动化测试的新人
  8. Azure 托管镜像和非托管镜像对比
  9. CentOS 7 Docker部署phpMyAdmin网站
  10. 要注意了!这样使用MyBatis框架,被攻击了!
  11. BZOJ3639 Query on a tree VII
  12. python写作_开源一个Python文档写作应用:MrDoc
  13. Visual FoxPro 9.0 Beta 可以下载了!
  14. ArcGIS地理数据处理高级教程_004_1遇到没有地理参照系信息的数据怎么办
  15. Wishbone总线快速了解
  16. 《ZigBee开发笔记》第五部分 外设篇 - 基础实验 第4章 CC2530热释电红外传感器
  17. 轻叩次元壁——谈谈真人头像的漫画化
  18. idea 导入别人的项目后,显示包的名称错误does not correspond to the file path
  19. 入门数据分析,需要会什么
  20. java面试题(无序版)

热门文章

  1. 河南科技学院计算机专业代码,河南科技学院专业代码
  2. lisp提取长方形坐标_在CAD中,用LISP如何提取三维多段端点坐标?
  3. 新窗口打开超链接的技巧
  4. ModuleNotFoundError: No module named ‘locust.events‘,httprunner执行locust压测报错解决办法~
  5. java收到邮件后短信提醒_java邮件发送和短信发送(一)
  6. (转)DataGrid资料
  7. easyui datagrid编辑时修改其它列的数值.
  8. 保护你的文件夹和文件
  9. 接码平台注册流程和使用
  10. python与vba_萝卜头python:PYTHON 与VBA互调