动态规划(6)下降路径最小值

给你一个 n x n方形 整数数组 matrix ,请你找出并返回通过 matrix下降路径最小和

下降路径 可以从第一行中的任何元素开始,并从每一行中选择一个元素。在下一行选择的元素和当前行所选元素最多相隔一列(即位于正下方或者沿对角线向左或者向右的第一个元素)。具体来说,位置 (row, col) 的下一个元素应当是 (row + 1, col - 1)(row + 1, col) 或者 (row + 1, col + 1)

示例 1:

复制代码
输入:matrix = [[2,1,3],[6,5,4],[7,8,9]]
输出:13
解释:如图所示,为和最小的两条下降路径
java 复制代码
public class Solution {
    public int minFallingPathSum(int[][] matrix) {
        //1.创建dp表
        //2.初始化
        //3.填表
        //4.返回值
        int n= matrix.length;
        int[][] dp =new int[n+1][n+2];
        for (int i=1;i<=n;i++)dp[i][n+1]=Integer.MAX_VALUE;
        for (int i=1;i<=n;i++)
            for (int j=1;j<=n;j++)
                dp[i][j] =Math.min(dp[i-1][j],Math.min(dp[i-1][j-1],dp[i-1][j+1]))+matrix[i-1][j-1];
        int ret=Integer.MAX_VALUE;
        for (int j=1;j<=n;j++)
            ret=Math.min(ret,dp[n][j]);
        return  ret;
        }

    public static void main(String[] args) {
        Solution solution=new Solution();
        int [][]matrix={{-19,57},{-40,5}};

        System.out.println(solution.minFallingPathSum(matrix));
    }
    }
相关推荐
篮l球场8 分钟前
数组中的第K个最大元素
数据结构·算法·leetcode
月落归舟18 分钟前
排序算法---(三)
数据结构·算法·排序算法
njidf24 分钟前
C++中的观察者模式
开发语言·c++·算法
2301_8227828227 分钟前
C语言数组通关攻略!从一维到字符数组,零基础也能轻松掌握
c语言·算法·数组·编程基础·避坑技巧
zhugby32 分钟前
标号法原理
算法
努力学习的小廉1 小时前
我爱学算法之——动态规划(一)
算法·动态规划
篮l球场1 小时前
前 K 个高频元素
数据结构·算法·leetcode
汉克老师1 小时前
GESP5级C++考试语法知识(十一、递归算法(一))
c++·算法·记忆化搜索·递归算法·递归优化
qq_148115372 小时前
C++网络编程(Boost.Asio)
开发语言·c++·算法
2301_804215412 小时前
内存映射文件高级用法
开发语言·c++·算法