算法五十一 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)

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

相关推荐
洛水水1 小时前
【力扣100题】62.滑动窗口最大值
数据结构·算法·leetcode
醒醒该学习了!1 小时前
Prompt提示词——带有深度思考模型的提示方法(理论篇)
人工智能·算法·prompt
君为先-bey1 小时前
Latte——视频生成的潜在扩散变换器
算法·机器学习·音视频·扩散模型
浅念-1 小时前
LeetCode刷题专题:FloodFill泛滥填充算法剖析
数据结构·算法·leetcode·职场和发展·深度优先·宽度优先
笨蛋不要掉眼泪1 小时前
Java并发编程:深入剖析 ArrayBlockingQueue
java·开发语言·算法·并发
菜菜的顾清寒1 小时前
力扣HOT100(33)二叉树的最大深度
算法·leetcode·职场和发展
Deepoch1 小时前
Deepoc数学大模型:重塑半导体研发与制造的核心算法范式
人工智能·算法·机器学习·半导体·deepoc·数学大模型
一支黑色の铅笔1 小时前
MongoDB Aggregation Pipeline 常用 Stage 速查
数据库·算法·mongodb
Bingorl1 小时前
机器学习之决策树算法
算法·决策树·机器学习