动态规划-931.下降路径最小和-力扣(LeetCode)

一、题目解析

从最顶上出发,有三个位置选择,左中下(边界除外),使其走到最下面时下降路径最小。

二、算法原理

1、状态表示

我们需要的是到达[i,j]的最小路径和,所以此时dp[i][j]表示:到达[i,j]位置时,最小的下降路径

2、状态转移方程

对于某个位置有三种下降方式,自然也就有三种到达该位置的方式

dp[i][j] 从[i-1,j-1]->[i,j]->dp[i-1][i-1]+matrix[i][j]

从[i-1,j]->[i,j]->dp[i-1][j]+matrix[i][j]

从[i-1][j+1]->[i,j]->dp[i-1][j+1]+matrix[i][j]

dp[i][j]=min(dp[i-1][j-1]+matrix[i][j],min(dp[i-1][j]+matrix[i][j],dp[i-1][j+1]+matrix[i][j]))

3、初始化

除了最上面一排初始化为0,其余位置要初始化为最大值,由于min的原因,如果都初始化为0,则会计算出错

4、填表顺序

从上往下,从左往右

5、返回值

由于到达最下面就停止了,所以取最后一排的最小值

自己动手实现一下吧,链接:931. 下降路径最小和 - 力扣(LeetCode)

三、代码示例

cpp 复制代码
class Solution {
public:
    int minFallingPathSum(vector<vector<int>>& matrix) {
        int n = matrix.size();
        vector<vector<int>> dp(n+1,vector<int>(n+2,INT_MAX));
        for(int j = 0;j<n+2;j++) dp[0][j] = 0;
        for(int i = 1;i<=n;i++)
        {
            for(int j = 1;j<=n;j++)
            {
                dp[i][j] = min(dp[i-1][j-1],min(dp[i-1][j],dp[i-1][j+1])) + matrix[i-1][j-1];
            }
        }
        int ret = INT_MAX;
        for(int j = 1;j<=n;j++) ret = min(ret,dp[n][j]);
        return ret;
    }
};

看到最后,如果对您有所帮助,还请点赞、收藏和关注,点点关注不迷路,我们下期再见!

相关推荐
澎恰恰oh1 分钟前
C++线程池的简单实现
c++
用户40315986396633 分钟前
和谐程序组
java·算法
用户40315986396635 分钟前
缓存优化模拟
java·算法
用户40315986396636 分钟前
遥控小车
java·算法
努力努力再努力wz31 分钟前
【c++深入系列】:万字详解list(附模拟实现的list源码)
运维·c语言·开发语言·数据结构·c++·list
羑悻的小杀马特1 小时前
从混沌到秩序:数据科学的热力学第二定律破局——线性回归的熵减模型 × 最小二乘的能量最小化 × 梯度下降的负反馈控制系统,用物理定律重构智能算法的统一场论
人工智能·算法·机器学习
仟濹1 小时前
【数据结构】「栈」(顺序栈、共享栈、链栈)
c语言·数据结构·算法
青梅主码1 小时前
2025年7月全球大模型最新排名发布!企业与个人该如何选择最适合你的 AI 得力助手?
人工智能·算法
许愿与你永世安宁1 小时前
强化学习 (11)随机近似
人工智能·算法·强化学习·梯度下降·随机近似
凤年徐2 小时前
【数据结构】栈和队列-----数据结构中的双生花
c语言·开发语言·数据结构·c++·笔记·算法·链表