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;
    }
}
相关推荐
yzx9910131 小时前
基于 Q-Learning 算法和 CNN 的强化学习实现方案
人工智能·算法·cnn
AWS官方合作商1 小时前
在CSDN发布AWS Proton解决方案:实现云原生应用的标准化部署
java·云原生·aws
亮亮爱刷题1 小时前
算法练习-回溯
算法
gadiaola2 小时前
【JVM】Java虚拟机(二)——垃圾回收
java·jvm
眼镜哥(with glasses)2 小时前
蓝桥杯 国赛2024python(b组)题目(1-3)
数据结构·算法·蓝桥杯
coderSong25684 小时前
Java高级 |【实验八】springboot 使用Websocket
java·spring boot·后端·websocket
Mr_Air_Boy5 小时前
SpringBoot使用dynamic配置多数据源时使用@Transactional事务在非primary的数据源上遇到的问题
java·spring boot·后端
豆沙沙包?6 小时前
2025年- H77-Lc185--45.跳跃游戏II(贪心)--Java版
java·开发语言·游戏
年老体衰按不动键盘6 小时前
快速部署和启动Vue3项目
java·javascript·vue
咖啡啡不加糖6 小时前
Redis大key产生、排查与优化实践
java·数据库·redis·后端·缓存