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 的值。

相关推荐
小欣加油13 小时前
leetcode 42 接雨水
c++·算法·leetcode·职场和发展
tankeven14 小时前
动态规划专题(14):石子合并问题(未完待续)
c++·算法·动态规划
EnglishJun14 小时前
ARM嵌入式学习(二十一)--- Platform总线结合dts、gpio子系统、中断和错误处理
arm开发·学习
CC城子14 小时前
EtherCAT的igh学习与研究(一)
学习·ethercat
xian_wwq14 小时前
【学习笔记】GB/T 20986-2023 详解,10 类网络安全事件分类
笔记·学习·web安全
像素猎人14 小时前
大学算法类竞赛的常用模板【自己总结+收录的】【c++版】
数据结构·算法·排序算法·算法竞赛常用算法
鱼鳞_14 小时前
Java学习笔记_Day27(Stream流)
java·笔记·学习
码云数智-大飞14 小时前
分布式锁的“双雄对决”:Redis 与 ZooKeeper 的深度博弈与选型指南
算法
_李小白14 小时前
【OSG学习笔记】Day 42: OSG 动态场景安全修改
笔记·学习·安全
H_老邪14 小时前
Docker 学习之路-从入门到放弃:7
学习·docker·容器