算法五十一 64. 最小路径和

64. 最小路径和

动态规划:

java 复制代码
class Solution {
    public int minPathSum(int[][] grid) {
        //子问题:到dp[i][j]的最小路径和
        //动态方程:dp[i][j] = Math,min(dp[i-1][j],dp[i][j-1]) + grid[i][j]

        //竖直长度
        int m = grid.length;
        //水平长度
        int n = grid[0].length;
        int[][]dp = new int[m][n];
        dp[0][0] = grid[0][0];

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

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

时间复杂度:O(mn)

空间复杂度:O(mn)

思路:找到状态方程,本质上到每个点的最小路径和为它左边的值与上面的值进行比较,取最小值即可;第一行和第一列可以单独拉出来写,更严谨便于理解

相关推荐
凌波粒10 小时前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
啵啵啵鱼10 小时前
数组---完
算法·排序算法
嘿黑嘿呦10 小时前
chap 8排序
算法·蓝桥杯·排序算法·软件工程
richdata10 小时前
需求预测终极指南:零售商品预测方法、算法与AI实践
人工智能·算法·零售
隔窗听雨眠11 小时前
C语言函数递归从入门到精通(下):性能优化与工程实践
c语言·算法·性能优化
退休倒计时11 小时前
【每日一题】LeetCode 146. LRU 缓存 TypeScript
算法·leetcode·缓存·typescript
珊瑚里的鱼11 小时前
【递归】汉诺塔
算法·深度优先
MrZhao40011 小时前
一个最小 Agent 是怎么跑起来的:Agent Loop 与工具使用全链路
算法
Keven_1111 小时前
算法札记:二分
算法·二分
TCW112111 小时前
AI底层系列:用C++实现线性代数的公式推导与算法设计-6.线性方程组的解集
c++·人工智能·算法