You have been given 2 special, extremely rugged Xboxes. You are in an office building that is 100 stories high. Using the fewest possible number of drops from windows in your office building, determine the highest floor you can drop an Xbox from and have it survive: for example, they might be able to take the drop from the 30th floor, but not the 31st. You can break both Xboxes in your search. State the worst case number of drops needed and explain how you arrived at that answer.
你在一幢100层的办公楼里上班,现在给你两台xbox(已经特意捆绑包扎好),要求你用尽可能少的试摔次数来判断xbox摔不坏的最高楼层层数。比方说,从30层丢下来没问题,但从31层丢下来就不保了。在摸索过程中,允许把两台xbox都砸烂。在最坏情况下,使得试摔次数尽可能小。
- 问题答案必须是在最坏情况下,时间复杂度最小。
- 最容易想到的就是二分法,三分法,多分法,但它们并不符合要求。比如:在50层丢一个,被砸烂。然后在25层丢另外一个,同样被砸烂。此时根本无从找到问题答案。
- 第二个想到的方法就是分段。(1)用第一个xbox寻找损坏区间;(2)用第二个xbox遍历该区间寻找损坏层。假定最优区间长度是x,则第一步最多要摔100/x(大于等于此值的最小整数)次,第二步最多摔x-1次,问题转换为求100/x+(x-1)的最小值。具体描述:以10层楼为一个区间,先摔第一个,以确定摔坏的区间,然后再用另一个在这个区间内从最低的楼层摔,从而找到所要求层数,这种方法最多要摔19次。
- 在“分段”方法中,段区间都是相等的。如果段区间不等,是不是可以找到最优的方法呢?假设最终答案至少要摔n次,那第一次顶多从n层楼摔。如果坏了,第二 个从1至n-1层最多摔n-1次就可以判断了;如果没坏,那么搜索范围改为[n+1,100],相当于搜索空间减少了n层。如果第一次没坏,第二次顶多再 减少n-1的搜索空间。依次类推,当第n次时顶多再减少1的搜索空间。n次之后,顶多排除n+(n-1)+(n-2)+...+1 = n*(n+1)/2个楼层。只要n*(n+1)/2 >= 100就可以了,满足这个条件的最小n为14。具体描述:从14楼丢一个,如果碎了,从1楼开始到13楼为止丢另一个,不碎,在14+13楼丢;...
给一个包含n个元素的数组,{a[1],...,a[n]},a[1]+a[2]+...+a[n]=100。那么如果第k次摔坏了第1台xbox ,那么此时最坏情况下总共需要的次数是k+a[k]-1我们把这个记为cost[k]。此时,问题可以重新描述为:找到一个满足上述条件的数组,{a[1],...,a[n]} ,使得 max<k=1>(cost[k])最小。
sigma<k=1>( cost[k] )
= (1+a[1]-1) + (2+a[2]-1) + (3+a[3]-1) ... + (n+a[n]-1)
= (1+2+3+ ... +n) + (a[1]+a[2]+a[3]+ ... +a[n]) - n
= n*(n+1)/2 + 100 - n
这个式子是个常量仅与n有关,与{a[1],...,a[n]}的具体数值无关。同时,不难看出 max<k=1>( cost[k] ) >= sigma<k=1>( cost[k] ) / n (最大值总是大于平均值),而且仅当 cost[1] =cost[2] = ... cost[n] 的时候,max...可以取到这个最小值。因此,对于任意给定的n,满足 cost[1]= cost[2] = ... cost[n]的解就是最优解。也就是说k+a[k]-1=1+a[1]-1,从而a[k]=a[1]-k+1 。那么a[2]=a[1]-1,a[3]=a[1]-2=a[2]-1...
参考:(1)
摔xbox的题目</k=1></k=1></k=1></k=1>
分享到:
相关推荐
基本算法---计数.sb3
算法初步课件 1.2.2 基本算法语句--条件语句.ppt
2. **wK算法** - 一种专用于处理SAR数据的算法,可能涉及到去除噪声、提高信噪比、恢复图像细节等步骤,但其具体实现和原理没有公开。 3. **Matlab编程** - 作为强大的科学计算工具,Matlab在遥感和图像处理领域有...
在机器人路径规划领域,优化算法起着至关重要的作用,它能帮助找到最有效、最经济的运动轨迹。本文将深入探讨“粒子群算法优化3-5-3多项式工业机器人时间最优轨迹规划算法”这一主题,以及如何在MATLAB环境下实现这...
MIMO预编码算法MATLAB实现-ZF、MMSE、SVD、BD
多目标遗传算法(NSGA-III)matlab源代码 多目标遗传算法(NSGA-III)matlab源代码 多目标遗传算法(NSGA-III)matlab源代码 多目标遗传算法(NSGA-III)matlab源代码已验证
该算法的基本思想是通过测量信号从一个发射器到多个接收器的时间差来计算目标的距离。其主要步骤如下: 1. **信号同步**:首先,接收端需与发射端进行时钟同步,确保时间基准一致。 2. **TDOA估计**:记录下信号...
在这个“1小时入门遗传算法——遗传算法excel手算例”中,我们将深入理解遗传算法的基本原理,并通过Excel这个直观易用的工具来手动实现一个简单的遗传算法实例。 首先,我们要了解遗传算法的核心概念。遗传算法...
算法可视化--数据结构课程设计。目前支持了其中基本排序算法以及迪杰斯特拉算法可视化,欢迎学弟学妹Fo_algorithmVisualize
神经网络算法的基本介绍,其中也说明了神经网络算法与网格计算的区别
2. `(BM)A Fast String Searching Algorithm.pdf`:这可能是Boyer-Moore算法的详细解释或原始论文。 3. `Aho-Corasick.pdf`:这个文件很可能是Aho-Corasick算法的详细介绍或者原始论文。 4. `(AC-BM)getPDF.pdf`:这...
此PDF教材可能涵盖这些基本概念,并通过实例代码展示C语言中如何实现这些数据结构和算法。学习者不仅可以了解理论知识,还能动手实践,提升编程能力。通过学习,读者应能理解各种数据结构的特点和适用场景,掌握常见...
包含空间谱估计理论与算法(王永良)课本对应各章的matlab程序 MATLAB程序:第2章_空间谱估计基础; 第3章_线性预测算法;第4章_多重信号分类算法;第5章_最大似然及子空间拟合算法;第6章_旋转不变子空间算法;第7...
使用matlab编写NSGA-2多目标优化算法: 1)针对测试函数集ZDT1进行的NSGA-Ⅱ算法的编写; 2)本程序有详细的备注解释; 3)包含论文《非支配排序遗传算法(NSGA)的研究与应用》.pdf,用来指导学习NSGA-Ⅱ算法
Matlab作为强大的数学和工程计算工具,为实现S型加减速算法提供了便利的平台。 S型加减速曲线,也称为三次多项式曲线,其形状类似于字母"S",由加速阶段、匀速阶段和减速阶段组成。这种曲线在启动时缓慢加速,达到...
其基本思想如下,假设边缘节点的 K-shell值为 1,然后往内一层层进入网络的核心,先去除网络 中度值等于 1 的所有节点以及连边。 若剩下的节点里面,仍有度值等于 1 的节点,则重复上述操作,即去除这些节点和连边...
最近在研习算法导论,发现课后习题的精彩程度甚至不亚于正文,对于算法导论的爱好者而言,这是一份不错的参考资料
ECC算法校验工具ECC算法校验工具ECC算法校验工具
K-Means算法的基本步骤如下: 1. **初始化**:首先,随机选择K个样本作为初始的聚类中心(Centroids)。 2. **分配样本**:将所有数据点按照与这K个中心的距离,分配到最近的类别中。距离通常使用欧氏距离计算。 ...
算法方面,书中可能涵盖了排序(如冒泡排序、选择排序、插入排序、快速排序、归并排序、堆排序等)、搜索(如线性搜索、二分搜索、深度优先搜索、广度优先搜索)、图算法(如Dijkstra算法、Floyd算法求最短路径,...