百层高塔扔鸡蛋问题新思路

2024-03-12 17:30

本文主要是介绍百层高塔扔鸡蛋问题新思路,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

百层高塔扔鸡蛋问题新思路

题目

两个软硬程度一样但未知的鸡蛋,它们有可能都在一楼就摔碎,也可能从一百层楼摔下来没事。有座100层的建筑,要你用这两个鸡蛋确定哪一层是鸡蛋可以安全落下的最高位置。可以摔碎两个鸡蛋。 最少需要几次测试,才能得到摔碎鸡蛋的楼层?方案如何?

原文链接:http://blog.sina.com.cn/s/blog_6c813dbd0101bh98.html

本文的思路为原创,思路与原文思路完全不同,如有发现讲解有问题,请留言指出,谢谢~

问题解析

这是一个不确定问题的分析,既然是不确定,那么我们只能考虑最差的情况,只要保障证最差情况下能完成任务,那么问题就得到了解决。我说这句话什么意思呢?举个例子:

假如我们第一次测试把鸡蛋在50层扔下时鸡蛋破了;那么此时我们只剩下一个鸡蛋,这个时候,为了保证我们一定能够测出鸡蛋刚好在哪一层能破,我们只能从第一层,一层一层网上尝试。最坏的情况就是鸡蛋刚刚好在49层摔破,这时候我们一共尝试了50次。这就是这种情况下最坏的情况了。假如没有破,那么问题就 转化成了重新尝试100-50层的问题了。依次类推。

所以我们假设在最少需要测试的次数时,第一次选的楼层是k(1<=k<=100)层,那么此时有两种结果:

1:鸡蛋没破碎

2:鸡蛋碎了

此时我们可以用如下图表示:

在这里插入图片描述

假如鸡蛋破了,我们需要一层一层的尝试,总共需要尝试k次:

在这里插入图片描述

假如鸡蛋没破,问题就转换成了最初的问题了,只不过楼层由100层减少到了100-k层,递归进行下去:

在这里插入图片描述

一次递归下去,知道还剩下1层楼:

在这里插入图片描述

我们可以看出,这是一颗二叉树,每一个节点就是我们尝试扔的楼层,树的深度,就是我们需要尝试的次数,而这颗树的总节点数,就是最大楼层数。

观察这棵树的特点,每一层的节点数都比上一层的节点数多一个,并且这一层的节点数和当前层数相等。所以为什么保证在任何最坏的情况下,我们都能在比较少的次数中尝试出最佳扔鸡蛋的楼层,我们要保证树的每一个分支的深度都尽可能的浅,也就是让这棵树的深度尽可能的浅。我们设当前树的最大深度为n,所以可以得出:1+2+3+...+n>=100,即(1+n)*n/2>=100。得到n的最小值为14。

所以我们至少需要尝试14次。

这篇关于百层高塔扔鸡蛋问题新思路的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/802025

相关文章

MySQL的cpu使用率100%的问题排查流程

《MySQL的cpu使用率100%的问题排查流程》线上mysql服务器经常性出现cpu使用率100%的告警,因此本文整理一下排查该问题的常规流程,文中通过代码示例讲解的非常详细,对大家的学习或工作有一... 目录1. 确认CPU占用来源2. 实时分析mysql活动3. 分析慢查询与执行计划4. 检查索引与表

MySQL报错sql_mode=only_full_group_by的问题解决

《MySQL报错sql_mode=only_full_group_by的问题解决》本文主要介绍了MySQL报错sql_mode=only_full_group_by的问题解决,文中通过示例代码介绍的非... 目录报错信息DataGrip 报错还原Navicat 报错还原报错原因解决方案查看当前 sql mo

Spring Boot 整合 ShedLock 处理定时任务重复执行的问题小结

《SpringBoot整合ShedLock处理定时任务重复执行的问题小结》ShedLock是解决分布式系统中定时任务重复执行问题的Java库,通过在数据库中加锁,确保只有一个节点在指定时间执行... 目录前言什么是 ShedLock?ShedLock 的工作原理:定时任务重复执行China编程的问题使用 Shed

MYSQL事务死锁问题排查及解决方案

《MYSQL事务死锁问题排查及解决方案》:本文主要介绍Java服务报错日志的情况,并通过一系列排查和优化措施,最终发现并解决了服务假死的问题,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录问题现象推测 1 - 客户端无错误重试配置推测 2 - 客户端超时时间过短推测 3 - mysql 版本问

Git提交代码详细流程及问题总结

《Git提交代码详细流程及问题总结》:本文主要介绍Git的三大分区,分别是工作区、暂存区和版本库,并详细描述了提交、推送、拉取代码和合并分支的流程,文中通过代码介绍的非常详解,需要的朋友可以参考下... 目录1.git 三大分区2.Git提交、推送、拉取代码、合并分支详细流程3.问题总结4.git push

解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题

《解决IDEA使用springBoot创建项目,lombok标注实体类后编译无报错,但是运行时报错问题》文章详细描述了在使用lombok的@Data注解标注实体类时遇到编译无误但运行时报错的问题,分析... 目录问题分析问题解决方案步骤一步骤二步骤三总结问题使用lombok注解@Data标注实体类,编译时

大数据小内存排序问题如何巧妙解决

《大数据小内存排序问题如何巧妙解决》文章介绍了大数据小内存排序的三种方法:数据库排序、分治法和位图法,数据库排序简单但速度慢,对设备要求高;分治法高效但实现复杂;位图法可读性差,但存储空间受限... 目录三种方法:方法概要数据库排序(http://www.chinasem.cn对数据库设备要求较高)分治法(常

Vue项目中Element UI组件未注册的问题原因及解决方法

《Vue项目中ElementUI组件未注册的问题原因及解决方法》在Vue项目中使用ElementUI组件库时,开发者可能会遇到一些常见问题,例如组件未正确注册导致的警告或错误,本文将详细探讨这些问题... 目录引言一、问题背景1.1 错误信息分析1.2 问题原因二、解决方法2.1 全局引入 Element

关于@MapperScan和@ComponentScan的使用问题

《关于@MapperScan和@ComponentScan的使用问题》文章介绍了在使用`@MapperScan`和`@ComponentScan`时可能会遇到的包扫描冲突问题,并提供了解决方法,同时,... 目录@MapperScan和@ComponentScan的使用问题报错如下原因解决办法课外拓展总结@

MybatisGenerator文件生成不出对应文件的问题

《MybatisGenerator文件生成不出对应文件的问题》本文介绍了使用MybatisGenerator生成文件时遇到的问题及解决方法,主要步骤包括检查目标表是否存在、是否能连接到数据库、配置生成... 目录MyBATisGenerator 文件生成不出对应文件先在项目结构里引入“targetProje