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;
    }
}
相关推荐
码出财富4 小时前
SpringBoot 内置的 20 个高效工具类
java·spring boot·spring cloud·java-ee
多米Domi0115 小时前
0x3f第33天复习 (16;45-18:00)
数据结构·python·算法·leetcode·链表
我是小疯子665 小时前
Python变量赋值陷阱:浅拷贝VS深拷贝
java·服务器·数据库
森叶5 小时前
Java 比 Python 高性能的原因:重点在高并发方面
java·开发语言·python
二哈喇子!5 小时前
Eclipse中导入外部jar包
java·eclipse·jar
微露清风5 小时前
系统性学习C++-第二十二讲-C++11
java·c++·学习
罗湖老棍子5 小时前
【例4-11】最短网络(agrinet)(信息学奥赛一本通- P1350)
算法·图论·kruskal·prim
方圆工作室5 小时前
【C语言图形学】用*号绘制完美圆的三种算法详解与实现【AI】
c语言·开发语言·算法
Lips6116 小时前
2026.1.16力扣刷题
数据结构·算法·leetcode
进阶小白猿6 小时前
Java技术八股学习Day20
java·开发语言·学习