给出一个二维数组,一个人从左上角出发,最终到达右下角,沿途数字累积,求返回最小的累加和

本文主要是介绍给出一个二维数组,一个人从左上角出发,最终到达右下角,沿途数字累积,求返回最小的累加和,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题描述:给出一个二维数组arr,一个人从左上角出发,沿途只能向下或向左走,并且沿途的数数字都累加,最终到达右下角,求返回最小的累加和

举例:给出一个数组    int[][] arr = new int[][]{{3, 7,8,7}, {1, 2,6,4},{10,3,8,9},{8,1,2,0}};

需求是返回 12

解决思想:动态规划的解决方案,此处提供两个方案,一种是常规方案,另一种是节约内存的方案。

1、常规方案:

1.1、分析图如下:

人从左上角3的位置开始移动,每次只能向左或向右移动一步,到右下角0结束,找到过程最小值 12

此路径的值最小,为12 

1.2、核心代码如下:

/*** @author wanghuainan* @date 2021/7/5 10:28*/
public class NanDaoMinPathSum {public static void main(String[] args) {//     int[][] arr = new int[10][10];int[][] arr = new int[][]{{3, 7,8,7}, {1, 2,6,4},{10,3,8,9},{8,1,2,0}};//  arr = new int[][]{{2, 3}, {1, 1}};System.out.println(minSumPath1(arr));}private static int minSumPath1(int[][] arr) {//边界判断if(arr.length == 0 || arr == null || arr[0] == null || arr[0].length == 0){return 0;}int row = arr.length;int col = arr[0].length;int[][] dp = new int[row][col];//定义一个缓存数组dp[0][0] = arr[0][0];//左上角赋值//第一列赋值for(int i = 1;i < row;i++){dp[i][0] = dp[i - 1][0] + arr[i][0];}//第一行赋值for(int j = 1;j < col;j++){dp[0][j] = dp[0][j - 1] + arr[0][j];}//中间其他行列格子里赋最小值for(int i = 1;i < row;i++){for(int j = 1;j < col;j++){dp[i][j] = Math.min(dp[i - 1][j],dp[i][j - 1]) + arr[i][j];}}return dp[row - 1][col -1];//返回右下角的值}
}

2、节约内存的方案(此处按行计算,当然也可以按照列计算):

2.1、图示分析:

采用一维数组,?处的值是通过14或6中先取最小值,然后加上3,即值为9 

2.2、核心代码

/*** @author wanghuainan* @date 2021/7/5 10:28*/
public class NanDaoMinPathSum {public static void main(String[] args) {//     int[][] arr = new int[10][10];int[][] arr = new int[][]{{3, 7,8,7}, {1, 2,6,4},{10,3,8,9},{8,1,2,0}};//  arr = new int[][]{{2, 3}, {1, 1}};System.out.println(minSumPath2(arr));}private static int minSumPath2(int[][] arr) {if(arr == null || arr.length == 0 || arr[0] == null || arr[0].length == 0){return 0;}int row = arr.length;int col = arr[0].length;int[] dp = new int[col];//一维数组,仅保存一行有效数据,节约内存dp[0] = arr[0][0];//初始化第一行数据for(int j = 1;j < col;j++){dp[j] = dp[j - 1] + arr[0][j];}for(int i = 1;i < row; i++){dp[0] +=arr[i][0];for(int j = 1;j < col;j++){//得出数组中j位置的数值,左边dp[j]代表j位置最新数值,右边dp[j]代表上一行历史数据,加上m[i][j]后得到j处最新数值dp[j] = Math.min(dp[j - 1],dp[j]) + arr[i][j];}}return dp[col - 1];}}

3、两种方案的执行结果:

到此,此算法的解决方案分享完毕,这到算法算是比较简单的问题,大家一定要多多联系,定会进步很快!

这篇关于给出一个二维数组,一个人从左上角出发,最终到达右下角,沿途数字累积,求返回最小的累加和的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/832251

相关文章

Python实现特殊字符判断并去掉非字母和数字的特殊字符

《Python实现特殊字符判断并去掉非字母和数字的特殊字符》在Python中,可以通过多种方法来判断字符串中是否包含非字母、数字的特殊字符,并将这些特殊字符去掉,本文为大家整理了一些常用的,希望对大家... 目录1. 使用正则表达式判断字符串中是否包含特殊字符去掉字符串中的特殊字符2. 使用 str.isa

Java数组初始化的五种方式

《Java数组初始化的五种方式》数组是Java中最基础且常用的数据结构之一,其初始化方式多样且各具特点,本文详细讲解Java数组初始化的五种方式,分析其适用场景、优劣势对比及注意事项,帮助避免常见陷阱... 目录1. 静态初始化:简洁但固定代码示例核心特点适用场景注意事项2. 动态初始化:灵活但需手动管理代

Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案

《Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案》:本文主要介绍Vue3组件中getCurrentInstance()获取App实例,但是返回nu... 目录vue3组件中getCurrentInstajavascriptnce()获取App实例,但是返回n

C++中初始化二维数组的几种常见方法

《C++中初始化二维数组的几种常见方法》本文详细介绍了在C++中初始化二维数组的不同方式,包括静态初始化、循环、全部为零、部分初始化、std::array和std::vector,以及std::vec... 目录1. 静态初始化2. 使用循环初始化3. 全部初始化为零4. 部分初始化5. 使用 std::a

shell编程之函数与数组的使用详解

《shell编程之函数与数组的使用详解》:本文主要介绍shell编程之函数与数组的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录shell函数函数的用法俩个数求和系统资源监控并报警函数函数变量的作用范围函数的参数递归函数shell数组获取数组的长度读取某下的

前端下载文件时如何后端返回的文件流一些常见方法

《前端下载文件时如何后端返回的文件流一些常见方法》:本文主要介绍前端下载文件时如何后端返回的文件流一些常见方法,包括使用Blob和URL.createObjectURL创建下载链接,以及处理带有C... 目录1. 使用 Blob 和 URL.createObjectURL 创建下载链接例子:使用 Blob

Python获取C++中返回的char*字段的两种思路

《Python获取C++中返回的char*字段的两种思路》有时候需要获取C++函数中返回来的不定长的char*字符串,本文小编为大家找到了两种解决问题的思路,感兴趣的小伙伴可以跟随小编一起学习一下... 有时候需要获取C++函数中返回来的不定长的char*字符串,目前我找到两种解决问题的思路,具体实现如下:

使用Sentinel自定义返回和实现区分来源方式

《使用Sentinel自定义返回和实现区分来源方式》:本文主要介绍使用Sentinel自定义返回和实现区分来源方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Sentinel自定义返回和实现区分来源1. 自定义错误返回2. 实现区分来源总结Sentinel自定

使用PyTorch实现手写数字识别功能

《使用PyTorch实现手写数字识别功能》在人工智能的世界里,计算机视觉是最具魅力的领域之一,通过PyTorch这一强大的深度学习框架,我们将在经典的MNIST数据集上,见证一个神经网络从零开始学会识... 目录当计算机学会“看”数字搭建开发环境MNIST数据集解析1. 认识手写数字数据库2. 数据预处理的

java字符串数字补齐位数详解

《java字符串数字补齐位数详解》:本文主要介绍java字符串数字补齐位数,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java字符串数字补齐位数一、使用String.format()方法二、Apache Commons Lang库方法三、Java 11+的St