力扣热门100题之最小路径和

核心思路

  • 只能右 / 下
  • 到达 (i,j) 的最小和 = min (上面来,左边来) + 当前格子值
  • 第一行、第一列要先累加好

转移方程

复制代码
dp[i][j] = Math.min(dp[i-1][j], dp[i][j-1]) + grid[i][j];

通俗解释

  1. 第一列:只能从上边走下来,所以一路累加
  2. 第一行:只能从左边走过来,一路累加
  3. 中间格子
    • 从上面来的代价:grid[i-1][j]
    • 从左边来的代价:grid[i][j-1]
    • 小的那个,再加上当前格子数值

完整代码实现:

java 复制代码
class Solution {
    public int minPathSum(int[][] grid) {
        int m = grid.length;
        int n = grid[0].length;

        //第一列累加
        for(int i = 1;i<m;i++){
            grid[i][0] += grid[i-1][0];
        }
        //第一行累加
        for(int j = 1;j<n;j++){
            grid[0][j] += grid[0][j-1];
        }

        //中间:取上,左较小值 + 当前值
        for(int i = 1;i<m;i++){
            for(int j =1;j<n;j++){
                grid[i][j] += Math.min(grid[i-1][j],grid[i][j-1]);
            }
        }
        return grid[m-1][n-1];
    }
}
相关推荐
chao1898443 小时前
基于 SPEA2 的多目标优化算法 MATLAB 实现
开发语言·算法·matlab
沪漂阿龙3 小时前
AI大模型面试题:支持向量机是什么?间隔最大化、软间隔、核函数、LinearSVC 全面拆解
人工智能·算法·支持向量机
little~钰4 小时前
倍增算法和ST表
算法
知识领航员5 小时前
蘑兔AI音乐深度实测:功能拆解、实测表现与适用场景
java·c语言·c++·人工智能·python·算法·github
薛定e的猫咪5 小时前
因果推理研究方向综述笔记
人工智能·笔记·深度学习·算法
如何原谅奋力过但无声6 小时前
【灵神高频面试题合集06-08】反转链表、快慢指针(环形链表/重排链表)、前后指针(删除链表/链表去重)
数据结构·python·算法·leetcode·链表
平行侠6 小时前
037插入排序 - 整理扑克牌的算法
数据结构·算法
ECT-OS-JiuHuaShan6 小时前
彻底定理化:从量子纠缠到量子代谢
数据库·人工智能·学习·算法·生活·量子计算
爱喝雪碧的可乐7 小时前
2026 腾讯广告算法大赛优秀方案启示:行为条件化多模态自回归生成推荐摘要
算法·数据挖掘·回归·推荐系统·推荐算法