1.有1栋100层高的楼和两颗玻璃球。在一定的高度摔下玻璃球将会摔碎。请给定一个方法来确定玻璃球摔碎的临界楼层。并说明该方法的最好情况,最差情况以及方法的复杂度(楼层为N层时)。

分析:由于只有两个球,那么二分法、三分法就不行了,比如在50层丢一个,被摔坏。然后在25层丢另外一个,同样被摔坏,此时根本无从找到问题答案。

其次想到的是分段,用第一个球寻找损坏区间,然后用第二球去遍历那个区间去寻找损坏层。

假定最优区间长度是x,则第一步最多要摔100/x次,第二步最多摔x-1次,问题转换为求100/x+(x-1)的最小值。

具体描述:以10层楼为一个区间,先摔第一个,以确定摔坏的区间,然后再用另一个在这个区间内从最低的楼层摔,从而找到所要求层数,这种方法最多要摔19次。

然而这种等长区间也是有问题,第一次我们需要判断的范围是100,然而摔下第一个球的时候,判断区间就改变了,如果碎了,那么就进入第二个步骤了。如果没有碎,那么需要判断的区间就变成了x+1到100。由于他的区间变小,应该可以有更优的选择,而不适宜沿用之前的定长区间。

假设最终需要测试的次数的为x,我们在x楼层摔下第一个玻璃球,球摔坏了,那么最多需要的楼层为1到x-1,即总测试次数为1+(x-1)=x

如果球未损坏,那么我们的测试范围变成了x+1层到100层,即测试范围减少了x层。

当我们再次摔下第一个球的时候,为了保证最终的测试次数为x,那么需要增长x-1,即为x+x-1层。

如果还没有摔坏,那么为了保证最终的结果仍为x,那么我们需要增长x-2,即为x+(x-1)+(x-2)层。

以此类推,直到增长区间为1时,由于我们设定这个x为最差情况,因此最终可搜索的楼层是可能超过100层的,即x+(x-1)+(x-2)+(x-3)....+1>=100。

到此我们终于明白了,这不是等差数列吗,等差数列公式是(首项+末项)×项数÷2,那么可以得到

(x+1)*x/2 >=100,由此我们求的x最小值为14。

具体描述:

先从14层扔(碎了试1-13)

再从27层扔(碎了试15-26)

再从39层扔(碎了试28-38)

再从50层扔(碎了试40-49)

再从60层扔(碎了试51-59)

再从69层扔(碎了试61-68)

再从77层扔(碎了试70-76)

再从84层扔(碎了试78-83)

再从90层扔(碎了试85-89)

再从95层扔(碎了试91-94)

再从99层扔(碎了试96-98)

最后从100层扔

转载于:https://blog.51cto.com/heimapangzi/1888077

最近智商拙计,做做题补一下相关推荐

  1. 做算法题时的一些小技巧

    做算法题时的一些小技巧 技巧一: 在用C++做算法题时,我们会觉的cin,cout比scanf,printf使用起来更加的方便,不用指定输入输出格式. 但是cin,cout的运行时间比scanf,pr ...

  2. c语言题-牛牛做水题

    牛牛喜欢做题.但他不喜欢做难题,喜欢做水题. 对于一个题号为的题而言,题目的难度为的所有因子之和除以.牛牛认为难度小于2的题目都是水题. 例如: 编号为25的题目,其难度为(1+5+25)/25=1. ...

  3. 投篮c语言程序设计,教师招聘笔试体育之篮球必做20题(一)

    教师招聘笔试体育之篮球必做20题(一) 一.单项选择题 1.篮球是最基本的区域联防战术是( )站位. A.2-1-2 B.2-3 C.3-2 D.1-3-1 2.国际篮球规定,球员的球衣号码必须是从( ...

  4. java 2017腾讯面试题_腾讯2017刁难面试题,是不是大神就看你会做几题

    原标题:腾讯2017刁难面试题,是不是大神就看你会做几题 一.今日头条2017笔试题(决策问题) 现在有两堆石子,小今与小条玩游戏,2个人都足够聪明,两个人规定:每次每人只能从其中一堆中取走1个或2个 ...

  5. 由浅入深学java iso_由浅入深学Java:基础、进阶与必做260题 PDF扫描版[47MB]

    由浅入深学Java:基础.进阶与必做260题讲解了Java方方面面的知识,全书共分为4篇共28章,第1篇从最基本的JDK安装讲起,包括基本语法与数据类型.数组.字符串.程序控制语句.面向对象编程.继承 ...

  6. 由浅入深学java pdf_由浅入深学Java:基础、进阶与必做260题 PDF_IT教程网

    资源名称:由浅入深学Java:基础.进阶与必做260题 PDF 第1篇  语言基础篇 第1章  Java入门(教学视频:18分钟) 1.1  Java简介 1.2  Java的特点 1.3  JDK的 ...

  7. 自考软考需要做什么题,自考软考真题哪里有呢?

    除了可以自我提升,软考还能提供各式各样的帮助,包括但不限于北上广落户.孩子上学,人才引进.对于工作的人,报考培训班是不太现实的,时间没有那么自由,很多人会选择自考软考,那么自考软考需要做什么题呢?自考 ...

  8. 投资银行业务过关必做1500题

    品相描述: 本商品为电子资料(非纸质书,无需邮寄,不支持打印),购买成功后客服将人工发送激活密码(如果长时间没收到可主动联系店铺客服获取).由于软件的特殊性,本商品不支持退换货,请购买前先下载试用,确 ...

  9. 将c语言程序转化成伪代码,「第9篇」「做编程题方法3」「来点伪代码」

    学C语言是痛苦的,用C语言做编程题更加痛苦.这几天我看很多同学拿到一道编程题就在问"这道题怎么做?"."没思路呀没思路"."求大神帮忙看看" ...

  10. 做编程题没有思路怎么办

    [来信] 老师您好! 我是一名计算机专业大二的学生,我现在在做一系列c语言竞赛一些容易的题目,可是我发现我碰到的问题会很没有思路,不知道方向,看见网上的很多同学都能够解决,而我却不能,我不知道自己差到 ...

最新文章

  1. php ajax mysql 分页查询_基于PHP_MySql_Ajax的分页技术方案
  2. 某企业生产系统升级Linux系统及内核
  3. Python高级编程(二)
  4. oracle随机取数据
  5. 使用Nginx反向代理部署laravel和history模式的Vue项目[更新]
  6. 老司机整理对Nginx性能优化
  7. 基于属性加密的ABE算法的应用场景思考展望
  8. java thread safe_Java 线程安全 Thread-Safety
  9. 需要vmwareinstalldisk上的文件vmnet_手机上一键就能进行PDF与其他文件的相互转换,果然厉害到不行...
  10. DSP using MATlAB 示例Example2.10
  11. 16. Window close() 方法
  12. 几种降维思想方法总结
  13. mysql-cluster5.7搭建集群(实际测试有效)
  14. Oracle数据泵对已经存在的表加载索引
  15. 贪吃蛇c语言代贴吧,【图片】C语言小游戏~贪吃蛇【c语言吧】_百度贴吧
  16. DOS命令大全(存档自用)
  17. high sierra php,mac os high sierra下搭建php多版本-php5.2+php5.6-nginx
  18. 升级鸿蒙手机内数据会删除吗,鸿蒙系统:手机升级不会删除任何文件,包括APP的登录状态都不会掉...
  19. 格式化字符串你都懂了吗
  20. 04-积极的环境改变人(哈佛幸福课-全部英文)

热门文章

  1. CodeForces128A - Statues 解题报告
  2. PyCharm双击打不开怎么办?
  3. 快速在网站跳转支付宝付款链接
  4. 智能人物画像综合分析系统——Day6
  5. 云计算的三种服务模式:IaaS,PaaS和SaaS
  6. 反激开关电源的工作原理
  7. 动手学深度学习 - 11.1. 数学符号 (notation)
  8. 计算机待机英语,计算机休眠
  9. VMware Workstation Pro详细安装教程
  10. 首发:Meltdown漏洞分析与实践