温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

最近智商拙计,做做题补一下

发布时间:2020-07-06 09:54:55 来源:网络 阅读:767 作者:蛛蛛侠 栏目:开发技术

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层扔




向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI