动态规划(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));
    }
    }
相关推荐
.YM.Z7 小时前
【数据结构】:排序(一)
数据结构·算法·排序算法
Chat_zhanggong3457 小时前
K4A8G165WC-BITD产品推荐
人工智能·嵌入式硬件·算法
百***48077 小时前
【Golang】slice切片
开发语言·算法·golang
墨染点香7 小时前
LeetCode 刷题【172. 阶乘后的零】
算法·leetcode·职场和发展
做怪小疯子7 小时前
LeetCode 热题 100——链表——反转链表
算法·leetcode·链表
做怪小疯子9 小时前
LeetCode 热题 100——矩阵——旋转图像
算法·leetcode·矩阵
努力学习的小廉9 小时前
我爱学算法之—— BFS之最短路径问题
算法·宽度优先
高山上有一只小老虎10 小时前
构造A+B
java·算法
木头左10 小时前
缺失值插补策略比较线性回归vs.相邻填充在LSTM输入层的性能差异分析
算法·线性回归·lstm
sin_hielo10 小时前
leetcode 2435
数据结构·算法·leetcode