【LeetCode热题100(87/100)】最小路径和

题目地址: 链接

状态转移方程:

d p i j = { g r i d 0 0 , 当 i = 1 且 j = 1 (起点) d p i − 1 1 + g r i d i − 1 0 , 当 i > 1 且 j = 1 (第一列) d p 1 j − 1 + g r i d 0 j − 1 , 当 i = 1 且 j > 1 (第一行) min ⁡ ( d p i − 1 j , d p i j − 1 ) + g r i d i − 1 j − 1 , 当 i > 1 且 j > 1 (非边界,取左/上最小路径和 + 当前值) dpij = \begin{cases} grid00, & \text{当 } i=1 \text{ 且 } j=1 \text{(起点)} \\ dpi-11 + gridi-10, & \text{当 } i>1 \text{ 且 } j=1 \text{(第一列)} \\ dp1j-1 + grid0j-1, & \text{当 } i=1 \text{ 且 } j>1 \text{(第一行)} \\ \min(dpi-1j, dpij-1) + gridi-1j-1, & \text{当 } i>1 \text{ 且 } j>1 \text{(非边界,取左/上最小路径和 + 当前值)} \end{cases} dpij=⎩ ⎨ ⎧grid00,dpi−11+gridi−10,dp1j−1+grid0j−1,min(dpi−1j,dpij−1)+gridi−1j−1,当 i=1 且 j=1(起点)当 i>1 且 j=1(第一列)当 i=1 且 j>1(第一行)当 i>1 且 j>1(非边界,取左/上最小路径和 + 当前值)

js 复制代码
/*
 * @lc app=leetcode.cn id=64 lang=typescript
 *
 * [64] 最小路径和
 */

// @lc code=start
function minPathSum(grid: number[][]): number {
    const [n, m] = [grid.length, grid[0].length];
    const dp = Array.from({length: n + 1}, () => new Array(m + 1).fill(0));
    dp[1][1] = grid[0][0];
    for(let i = 2; i <= n; i ++) dp[i][1] = dp[i - 1][1] + grid[i - 1][0];
    for(let i = 2; i <= m; i ++) dp[1][i] = dp[1][i - 1] + grid[0][i - 1];

    for(let i = 2; i <= n; i ++) {
        for(let j = 2; j <= m; j ++) {
            dp[i][j] = Math.min(dp[i - 1][j], dp[i][j - 1]) + grid[i - 1][j - 1];
        }
    }

    return dp[n][m];
};
// @lc code=end
相关推荐
kisshyshy10 小时前
🍦 雪糕、食堂、火车厢:三幅漫画吃透栈、队列与链表
javascript·算法
猿人谷18 小时前
不只是 CPU 阈值:STAR 如何用 GAT + Transformer 做容器级自动扩缩容?
人工智能·算法
复杂网络19 小时前
Stable Diffusion 视觉大模型微调技术深度调研
算法
复杂网络19 小时前
基于 Stable Diffusion 架构的视觉大模型代表性工作与原理深度解析
算法
MrZhao40019 小时前
Agent Loop 如何用 Hook 扩展:权限、日志与工具拦截
算法
MrZhao40019 小时前
Agent 为什么需要 Skills:别把所有知识都塞进 system prompt
算法
JieE2122 天前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2123 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack204 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树4 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色