DP学习第六篇之下降路径最小和

DP学习第六篇之下降路径最小和

931. 下降路径最小和 - 力扣(LeetCode)

一.题目解析

二. 算法原理

  1. 状态表示

tips: 经验+题目要求。以[i,j]位置为结尾,。。。

dp[i][j]: 到达[i, j]位置时,此时的最小下降路径和

  1. 状态转移方程

tips: 用之前或之后的状态,推导出dp[i]的值。根据最近的一步,来划分问题

到达[i, j]位置之前:

  • 从[i - 1, j]位置向下走一步,到[i, j]

  • 从[i - 1, j - 1]位置向右下↘走一步,到[i, j]

  • 从[i - 1, j + 1]位置向左下↙走一步,到[i, j]

    即:dp[i][j] = min(dp[i - 1][j], dp[i - 1][j - 1], dp[i - 1][j + 1]) + m[i][j]

  1. 初始化

tips: 保证填表的时候不越界。增加虚拟节点

  • 虚拟节点里面的值,要保证后面填表是正确的

要保证填表的正确性,即第一行的dp值应该等于m值,因此其依赖的虚拟节点应该为0。对于左右两侧,也要保证虚拟节点的值不影响正确性,应取正无穷

  • 下标的映射关系

dp表映射到原矩阵:横纵坐标-1

  1. 填表顺序

从左往右每一行,从上往下整个表

  1. 返回值

题目要求:到最后一行的最小路径和

即:返回最后一行dp表中的最小值

三. 编写代码

c++ 复制代码
class Solution {
public:
    int minFallingPathSum(vector<vector<int>>& matrix) {
        //1.创建dp表
        //2.初始化
        //3.填表
        //4.返回值
        int n = matrix.size();
        vector<vector<int>> dp(n + 1, vector<int>(n + 2, INT_MAX));

        for(int i = 0; i < n + 2; ++i)
            dp[0][i] = 0;
        
        for(int i = 1; i <= n ; ++i)
            for(int j = 1; j <= n; ++j)
                dp[i][j] = min(dp[i - 1][j], min(dp[i - 1][j + 1], dp[i - 1][j - 1])) 
                            + matrix[i - 1][j - 1];
            
        int mi = dp[n][1];
        for(int i = 2; i <= n; ++i)
            mi = min(mi, dp[n][i]);
        return mi;
    }   
};

🦀🦀观看~~

相关推荐
爱睡懒觉的焦糖玛奇朵2 小时前
【从视频到数据集:焦糖玛奇朵的魔法工具使用说明】
人工智能·python·深度学习·学习·算法·yolo·音视频
Runawayliquor2 小时前
opbase:CANN 所有算子的公共地基
大数据·数据库·人工智能·算法
徐安安ye2 小时前
FlashAttention 为什么对序列长度这么“敏感”?
人工智能·算法
夏天想3 小时前
人类将从“执行者“变为“总导演”,学习Ai知识
人工智能·学习
晓梦林3 小时前
Baji1靶场学习笔记
笔记·学习
希冀1234 小时前
【CSS学习第十一篇】
前端·css·学习
黎阳之光4 小时前
黎阳之光:以视频孪生重构智能监盘,为燃机打造新一代智慧电厂大脑
大数据·人工智能·算法·安全·数字孪生
绝知此事4 小时前
【算法突围 02】树形结构与数据库索引:树形结构与数据库索引:从 BST 到 B+ 树的演化与 MySQL 优化
数据库·mysql·算法·面试·b+树
魔法阵维护师5 小时前
从零开发游戏需要学习的c#模块,第十六章(安装 MonoGame 并创建第一个窗口)
学习·游戏·c#·monogame
xian_wwq5 小时前
【学习笔记】大模型备案到底要交什么材料
笔记·学习