作者:小树苗渴望变成参天大树
作者宣言:认真写好每一篇博客
作者gitee:gitee✨
作者专栏:C语言,数据结构初阶,Linux,C++ 动态规划算法\
如 果 你 喜 欢 作 者 的 文 章 ,就 给 作 者 点 点 关 注 吧!
hello,大家好,我们今天开始讲动态规划的第八题,这个题目相比较前面来说,再dp表上有了一点小变化,中间我会给大家讲解为什么要这么做,话不多说,我们开始进入正文
第八个题目是下降路径最小和
通过图解来看题目解析:
接下来用动态规划的步骤给大家讲解:
代码实现:
class Solution {
public:
int minFallingPathSum(vector<vector<int>>& matrix) {
//1.创建dp表
int n=matrix.size();
vector<vector<int>> dp(n+1,vector<int>(n+2,INT_MAX));//先将dp表都初始化为正无穷
//2.初始化
for(int i=0;i<=n+1;i++)dp[0][i]=0;//再把第一行变成0
//3.填表
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=dp[n][1];
for(int j=1;j<=n;j++)
ret=min(ret,dp[n][j]);
return ret;
}
}
这题的初始化非常巧妙,如果大家不理解,可以再填表的时候讲最左边和最右边的两种情况加一个判断,来看代码:
class Solution {
public:
int minFallingPathSum(vector<vector<int>>& matrix) {
//1.创建dp表
int n=matrix.size();
vector<vector<int>> dp(n+1,vector<int>(n+1));
//特殊情况
if(n==1)return matrix[n-1][n-1];
//3.填表
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
{
if(j==1)
{
dp[i][j]=min(dp[i-1][j],dp[i-1][j+1])+matrix[i-1][j-1];//上和右上
}
else if(j==n)
{
dp[i][j]=min(dp[i-1][j],dp[i-1][j-1])+matrix[i-1][j-1];//上和左上
}
else
{
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 min=dp[n][1];
for(int i=1;i<=n;i++)
{
if(dp[n][i]<=min)
{
min=dp[n][i];
}
}
//4.返回值
return min;
}
};
运行结果:
这题目总体来说难度不大,理解起来也还好,但是要分析每种情况对应的条件,还有初始化问题,及下标映射关系,这题就讲到这里了,我们下题再见