Java解决下降路径最小和

Java解决下降路径最小和

01 题目

给你一个 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
解释:如图所示,为和最小的两条下降路径

示例 2:

输入:matrix = [[-19,57],[-40,-5]]
输出:-59
解释:如图所示,为和最小的下降路径

提示:

  • n == matrix.length == matrix[i].length
  • 1 <= n <= 100
  • -100 <= matrix[i][j] <= 100

02 知识点

  • 双重循环
  • 二维数组
  • 动态规划

03 我的题解思路

java 复制代码
public class shuzu02 {
	public static void main(String[] args) {
//		测试数据
		int[][]	matrix = {
				{2,1,3},
				{6,5,4},
				{7,8,9}
		       	        		  };
		
		System.out.println(minFallingPathSum(matrix));
	}
	public static int minFallingPathSum(int[][] matrix) {
//		获取行数和列数
		int row=matrix.length;
		int col=matrix[0].length;
//		用二数数组来实现dp(动态规划)
//		动态规划,我的理解是用算法记录计算出结果的每一个阶段的过程值
		int[][] nums=new int[row][col];
		for (int i = 0; i < row; i++) {
//			每一行循环
			for (int j = 0; j <col; j++) {
//				每一列循环,当为第一行的时候,赋值并直接结束本次列循环
				if (i==0) {
					nums[0][j]+=matrix[i][j];
					continue;
				}
//				从第二行开始,到达第二行每一格都存在最优解,最优解(nums[i][j])=原本值(matrix[i][j])+上一行相邻格中最小值
//				循环找到上一行相邻格中最小值
				int min=Integer.MAX_VALUE;
				for (int j2 = j-1; j2 <j+2; j2++) {
//					为了放在数组越界,要去除临界值
					if (j2<0||j2>col-1) {
						continue;
					}
					min=Math.min(min, nums[i-1][j2]);
				}
				nums[i][j]=matrix[i][j]+min;	
			}
		}
//		最后再从结果表最后一行中取出最小路径和
		int min=Integer.MAX_VALUE;
		for (int i = 0; i < col; i++) {
			min=Math.min(min, nums[row-1][i]);
		}
		return min;
    }
}
相关推荐
bing_15816 分钟前
IOC三种实现方式的区别
java·spring
和风化雨16 分钟前
排序算法--希尔排序
c语言·数据结构·c++·算法·排序算法
代数狂人27 分钟前
Java泛型深度解析(JDK23)
java·开发语言
遗憾皆是温柔27 分钟前
JavaFX - 3D 形状
java·开发语言·ide·学习·3d
sjsjs1142 分钟前
【数据结构-Trie树】力扣677. 键值映射
数据结构·算法·leetcode
老马啸西风1 小时前
IM 即时通讯系统-45-merua0oo0 IM 分布式聊天系统
java·分布式·im
老马啸西风1 小时前
IM 即时通讯系统-50-[特殊字符]cim(cross IM) 适用于开发者的分布式即时通讯系统
java·分布式·ui·开源·im
0x7F7F7F7F1 小时前
图论——spfa判负环
算法·图论
励志成为美貌才华为一体的女子1 小时前
python算法和数据结构刷题[6]:二叉树、堆、BFS\DFS
数据结构·算法
wclass-zhengge1 小时前
04树 + 堆 + 优先队列 + 图(D1_树(D10_决策树))
数据结构·算法