LeetCode算法学习之鸡蛋掉落

完整代码实现

java 复制代码
class Solution {
    public int superEggDrop(int k, int n) {
        int[][] dp = new int[n + 1][k + 1];
        int m = 0;
        while (dp[m][k] < n) {
            m++;
            for (int i = 1; i <= k; i++) {
                dp[m][i] = dp[m - 1][i - 1] + dp[m - 1][i] + 1;
            }
        }
        return m;
    }
}

解题思路:

动态规划定义

定义 dp[m][k] 为用 k 枚鸡蛋和 m 次尝试,最多能检查的楼层数。其递推关系为:

如果在某一层扔鸡蛋:

鸡蛋碎了:剩下 k-1 枚鸡蛋和 m-1 次尝试,能检查 dp[m-1][k-1] 层。

鸡蛋没碎:剩下 k 枚鸡蛋和 m-1 次尝试,能检查 dp[m-1][k] 层。

当前层:无论碎没碎,当前层本身也算一层检查。

因此,状态转移方程为:

dp[m][k] = dp[m-1][k-1] + dp[m-1][k] + 1

初始化

dp[k] = 0:0 次尝试无法检查任何楼层。

dp[m] = m:只有 1 枚鸡蛋时,必须线性检查(最多 m 层)。

算法流程

初始化二维数组 dp:大小为 (n+1) x (k+1),所有元素初始为 0。

逐步增加尝试次数 m:

对于每个 m,计算 dp[m][i](i 从 1 到 k)。

当 dp[m][k] >= n 时,返回 m。

填充 dp 表:

按行(m)填充,每行更新所有鸡蛋数 i 的值。

相关推荐
良木生香3 分钟前
【C++初阶】STL——Vector从入门到应用完全指南(1)
开发语言·c++·神经网络·算法·计算机视觉·自然语言处理·数据挖掘
Brilliantwxx3 分钟前
【C++】String的模拟实现(代码实现与坑点讲解)
开发语言·c++·笔记·算法
憨波个12 分钟前
【说话人日志】DOVER:diarization 输出融合算法
人工智能·算法·音频·语音识别·聚类
babe小鑫14 分钟前
数据岗位的发展与学习数据分析指南
学习·数据挖掘·数据分析
爱学习的张大14 分钟前
具身智能论文问答(四):pi0
人工智能·算法
楼田莉子16 分钟前
仿Muduo的高并发服务器:Channel模块与Poller模块
linux·服务器·c++·学习·设计模式
知识分享小能手19 分钟前
R语言入门学习教程,从入门到精通,R语言网络关系数据可视化(8)
学习·信息可视化·r语言
上弦月-编程19 分钟前
指针编程:高效内存管理核心
java·数据结构·算法
罗超驿20 分钟前
双指针算法经典案例:LeetCode 283. 移动零(Java详解)
java·算法·leetcode
xieliyu.21 分钟前
Java手搓数据结构:栈与队列模拟实现
java·数据结构·学习