高楼扔鸡蛋问题

news/2024/5/9 6:08:48/文章来源:https://blog.csdn.net/qq_56999918/article/details/128162322

1.对应letecode链接
高楼扔鸡蛋问题

2.题目描述
在这里插入图片描述

解题思路

题目是这样:你面前有一栋从 1 到 N 共 N 层的楼,然后给你 K 个鸡蛋(K 至少为 1)。现在确定这栋楼存在楼层 0 <= F <= N,在这层楼将鸡蛋扔下去,鸡蛋恰好没摔碎(高于 F 的楼层都会碎,低于 F 的楼层都不会碎)。现在问你,最坏情况下,你至少要扔几次鸡蛋,才能确定这个楼层 F 呢?
也就是让你找摔不碎鸡蛋的最高楼层 F,但什么叫最坏情况至少要扔几次呢?我们分别举个例子就明白了。我们首先不用理这个鸡蛋的个数,现在假设有8层楼。我们在第一层楼开始扔这个鸡蛋。如果没碎那么我们就可以接着第二层扔这个鸡蛋,如果还没碎我们可以接着第三层开始扔。如果一直没碎的话我们最坏的情况下是不是需要尝试这个8次。而至少需要扔几次这又是什么意思?因为我们可以选择在第几号楼开始扔这个鸡蛋。假设我们现在在s层楼开始扔鸡蛋无非就只有两种情况一种是这个碎了,另外一种就是没碎。如果碎了的话那么答案只有可能在s-1层中,如果没碎那么答案在这个n-s层之中.在这一层开始扔的答案就是这个这两种情况下最坏的那种。随着我们开始扔鸡蛋层数的不同那么这个最话的这个结果也肯定不同。那么只需要在这么多结果当中选择代价最少的那种就可以了。

在这里插入图片描述
在这里需要注意的是如果鸡蛋没碎那么这个第i层我们可以将其当中这个第0层。下面我们来看看这个代码如何来书写。

class Solution {public:int superEggDrop(int k, int n) {return process(k, n);}//一共有n层楼k个鸡蛋返回最小扔鸡蛋的次数int process(int k, int n) {//如果只有一个鸡蛋那么最坏的情况下肯定是需要扔k层的if (k == 1) {return n;}//0层楼不用试肯定是0次if (n == 0) {return 0;}int ans = INT_MAX;for (int i = 1; i <= n; i++) {//枚举所有开始扔鸡蛋的层数在所有结果当中选择代价最小的一个ans = min(ans, max(process(k - 1, i - 1), process(k, n - i)) + 1);}return ans;}
};

但是这样很暴力即使我们加了这个记忆化搜索我们也过不了。下面我们看看这个记忆化搜索的代码如何实现。

class Solution {public:vector<vector<int>>dp;int superEggDrop(int k, int n) {dp.resize(k+1,vector<int>(n+1,-1));return process(k, n);}//一共有n层楼k个鸡蛋返回最小扔鸡蛋的次数int process(int k, int n) {//如果只有一个鸡蛋那么最坏的情况下肯定是需要扔k层的if (k == 1) {return n;}//0层楼不用试肯定是0次if (n == 0) {return 0;}if(dp[k][n]!=-1){return dp[k][n];}int ans = INT_MAX;for (int i = 1; i <= n; i++) {//枚举所有开始扔鸡蛋的层数在所有结果当中选择代价最小的一个ans = min(ans, max(process(k - 1, i - 1), process(k, n - i)) + 1);}dp[k][n]=ans;return ans;}
};

下面我们来看看这个方法二:
方法二有点偏数学方法,非常的难想到利用函数单调性进行二分。并不是像刚才那样一层楼一层楼的进行枚举,把枚举的过程做了一点优化。
在这里插入图片描述
我们可以看到dp(K,N)他只依赖这个。dp(K-1,i-1)和这个dp(K,N-i)如果我们把考虑鸡蛋的个数,而且那么dp(K-1,i-1)是单调递增的函数而这个dp(K,N-i)是这个单调递减的函数。我们要求他们两个的最大值最小的那个。当这两个函数相等的时候这个时候是最优解。下面我们看看这几种情况。

情况 1:最低点只有 1 个点
在这里插入图片描述

情况 2:最低点是若干个重合的点

在这里插入图片描述

情况 3:最低点不重合,但是两边的值一样

在这里插入图片描述
从图上可以看出:二者的较大值的最小点在它们交汇的地方。那么有没有可能不交汇,当然有可能(上面第 3 张图),二者较大值的最小者一定出现在画成曲线段交点的两侧,并且二者的差值不会超过 1,也就是如果没有重合的点,两边的最大值是一样的(从图上看出来的,没有严格证明),因此取左侧和右侧两点中的一点都可以,不失一般性,可以取左边的那个点的 k。也就是找到使得 dp[i - k][j] <= dp[k - i][j - 1] 最大的那个 k 值即可。

下面我们来看看代码如何来书写

class Solution {
public:vector<vector<int>>dp;int superEggDrop(int k, int n) {dp.resize(k+1,vector<int>(n+1,-1));return process(k,n);}int process(int k,int n){if(k==1){return n;}if(n==0){return 0;}if(dp[k][n]!=-1){return dp[k][n];}int ans=-1;int L=1;int R=n;//找到这个大于等于这个最大的数字while(L<=R){int mid=(L+R)/2;int l=process(k-1,mid-1);int r=process(k,n-mid);if(l<=r){ans=mid;L=mid+1;}else{R=mid-1;}}//在这一层肯定是这个最优的dp[k][n]=max(process(k-1,ans-1),process(k,n-ans))+1;return dp[k][n];}
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_229722.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

生命在于折腾——Fishing软件的编写(易语言)

本篇文章仅用于学习交流&#xff0c;不得用于其他违规用途。 一、钓鱼软件是什么&#xff1f; 钓鱼软件是通常以精心设计的虚假网页引诱用户上当,达到盗取银行账号、信用卡号码等目的,属于违法行为。 钓鱼通常指伪装成银行及电子商务,窃取用户提交的银行帐号、密码等私密信息…

解决JSP中Bean在页面显示不正确问题(scope关键字)

问题出现 有一天我在编写JSP的程序时&#xff0c;在Java后端写了跳转并且传输数据语句&#xff0c;但前端界面渲染出来的数据却是我在DAO中初始化的数据。 第一句语句将book对象注入request的Session中&#xff0c;第二句实现跳转到JSP页面&#xff0c;第三句将此时的request和…

vue3移动端适配的解决方案

文章目录前言一、使用插件① 纯wap项目效果&#xff1a;Demo&#xff1a;② pc&wap混合项目&#xff08;我放弃了&#xff09;二、老方案效果&#xff1a;Demo&#xff1a;前言 最近在给公司内部做一个BBS论坛&#xff0c;需要在电脑和手机上都可以操作&#xff0c;所以需…

找出链表中间结点的三种解法

初阶链表刷题注意&#xff01;&#xff01;&#xff01;学习的是解题的思维&#xff01; 找出链表的中间结点&#xff08;链接在末尾&#xff09; 解题思路 数组解法 由于链表不能通过下标访问对应的结点&#xff0c;所以我们将所有的结点存储在数组中&#xff0c;这样就可以通…

Vue中$nextTick实现源码解析

这篇文章主要为大家介绍了Vue中$nextTick实现源码解析&#xff0c;有需要的朋友可以借鉴参考下&#xff01; 先看一个简单的问题 {{ text }} 此时打印的结果是什么呢&#xff1f;是 old。如果想让它打印 new&#xff0c;使用 nextTick 稍加改造就可以 this.$nextTick(() >…

eBPF汇编指令你还不知道?看这一篇文就够了

【好文推荐】 一文看懂linux 内核网络中 RPS/RFS 原理 怎么在Windows下使用Makefile文件 浅析linux内核网络协议栈--linux bridge 大家好&#xff0c;我是你们的彦祖&#xff0c;今天这篇文主要介绍 eBPF 的指令系统&#xff0c;对于想深入理解 eBPF 的同学千万不要错过&#x…

WMS手动配货和自动配货的区别

手动配货 不知道配货流程的朋友可以看一下前面的文章链接: 深入浅出WMS之出库流程里面有对出库的解释说明&#xff0c;其中也有对配货的解释。前端页面也可以在前面的那篇文章中看到&#xff0c;这里我们来说一下后端部分。 查 手动配货是选中出库单的某条数据&#xff0c;然…

PyQt5基础练习1

0. 本文学习地址 1. PyQt5是由一系列Python模块组成 超过620个类&#xff0c;6000函数和方法。能在诸如Unix、Windows和Mac OS等主流操作系统上运行。 1.1 PyQt5有两种证书 GPL商业证书 2. 实验1 实现简单的窗体 2.1 完整代码 #!/usr/bin/python3 # -*- coding: utf-8 -*…

零基础学习软件测试,掌握四点就够了

近年来越来越多的人转行到软件测试这一领域&#xff0c;对于很多外行的人来说&#xff0c;肯定对这一行业有很多不了解&#xff0c;对于这一职业的职责以及要求都会不清楚&#xff0c;那么我们今天就来梳理一下关于软件测试行业的信息。 一、软件测试的主要职责你知道吗&#x…

[附源码]计算机毕业设计学生疫情防控信息填报系统Springboot程序

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

16.前端笔记-CSS-学成在线案例

1、CSS属性书写顺序 &#xff08;1&#xff09;布局定位属性 display/position/float/clear/visibility/overflow(建议display第一个写&#xff0c;关系到模式) &#xff08;2&#xff09;自身属性 width/height/margin/padding/border/background &#xff08;3&#xff09;文…

[附源码]计算机毕业设计springboot项目管理系统的专家评审模块

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

“极致成本向左,本质安全向右”-谈谈锂电池储能系统的发展趋势

极致成本 or 本质安全? 1 快速增长的电化学储能电站 根据CNESA全球储能项目库的不完全统计,截至 2021 年底,全球已投运电力储能项目累计装机规模 209.4GW, 同比增长 9%。其中,抽水蓄能的累计装机规模占比首次低于 90%,比去年同期下降4.1个百分点;新型储能的累计装机规模…

30张图 讲清楚Redis Cluster

今天下午和一位同学聊Redis集群&#xff0c;这玩意真没那么简单&#xff0c;内容非常多。 Redis Cluster是Redis官方提供的Redis集群功能。 1.为什么要实现Redis Cluster 1.主从复制不能实现高可用 2.随着公司发展&#xff0c;用户数量增多&#xff0c;并发越来越多&#x…

【人工智能/算法】搜索求解(Solving Problems by Searching)

文章目录一、求解与搜索二、盲目式搜索1. 深度优先搜索&#xff08;Depth First Search, DFS&#xff09;回溯搜索&#xff08;Backtracking Search&#xff09;2. 广度优先搜索&#xff08;Breadth First Search, BFS&#xff09;一致代价搜索&#xff08;Uniform-cost Search…

BBR 数学模型直观展示

看 BBR 的理想图示&#xff1a; 但现实中数据包到达并非绝对均匀&#xff0c;考虑统计突发&#xff0c;实际情况如下&#xff1a; ​后文将 Delivery Rate 设为 B(Bandwidth)&#xff0c;将 RTT 设为 D(Delay)。 B/inflt 曲线一定上凸&#xff0c;可想象 1 个 inflt 只有一种…

北京一互联网公司被端,所有开发被全部带走!

△Hollis, 一个对Coding有着独特追求的人△这是Hollis的第 407 篇原创分享作者 l Hollis来源 l Hollis&#xff08;ID&#xff1a;hollischuang&#xff09;近日&#xff0c;北京市朝阳公安分局对外公开&#xff0c;按照公安部“净网”专项行动整体部署&#xff0c;朝阳警方深入…

学习二十大奋进新征程线上知识答题活动回顾

学习二十大奋进新征程线上知识答题活动回顾 活动背景 开展直播宣讲、组织知识竞赛答题……各地通过多种形式广泛开展学习宣传活动&#xff0c;一起学。 为深入学习宣传贯彻二十大精神&#xff0c;近日&#xff0c;我市开展“奋进新征程&#xff0c;共创强国业”学习二十大精神…

Spring MVC统一异常处理的3种方式(附带实例)

在 Spring MVC 应用的开发中&#xff0c;不管是对底层数据库操作&#xff0c;还是业务层或控制层操作&#xff0c;都会不可避免地遇到各种可预知的、不可预知的异常需要处理。 如果每个过程都单独处理异常&#xff0c;那么系统的代码耦合度高&#xff0c;工作量大且不好统一&a…

SAS,Stata,HLM,R,SPSS和Mplus分层线性模型HLM分析学生受欢迎程度数据

全文链接&#xff1a;http://tecdat.cn/?p10809本文用于比较六个不同统计软件程序&#xff08;SAS&#xff0c;Stata&#xff0c;HLM&#xff0c;R&#xff0c;SPSS和Mplus&#xff09;的两级分层线性模型的过程和输出&#xff08;点击文末“阅读原文”获取完整代码数据&#…