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

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

问题描述:给出一个二维数组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

相关文章

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

基于Python实现数字限制在指定范围内的五种方式

《基于Python实现数字限制在指定范围内的五种方式》在编程中,数字范围限制是常见需求,无论是游戏开发中的角色属性值、金融计算中的利率调整,还是传感器数据处理中的异常值过滤,都需要将数字控制在合理范围... 目录引言一、基础条件判断法二、数学运算巧解法三、装饰器模式法四、自定义类封装法五、NumPy数组处理

Java中数组与栈和堆之间的关系说明

《Java中数组与栈和堆之间的关系说明》文章讲解了Java数组的初始化方式、内存存储机制、引用传递特性及遍历、排序、拷贝技巧,强调引用数据类型方法调用时形参可能修改实参,但需注意引用指向单一对象的特性... 目录Java中数组与栈和堆的关系遍历数组接下来是一些编程小技巧总结Java中数组与栈和堆的关系关于

Django HTTPResponse响应体中返回openpyxl生成的文件过程

《DjangoHTTPResponse响应体中返回openpyxl生成的文件过程》Django返回文件流时需通过Content-Disposition头指定编码后的文件名,使用openpyxl的sa... 目录Django返回文件流时使用指定文件名Django HTTPResponse响应体中返回openp

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

SpringBoot中使用Flux实现流式返回的方法小结

《SpringBoot中使用Flux实现流式返回的方法小结》文章介绍流式返回(StreamingResponse)在SpringBoot中通过Flux实现,优势包括提升用户体验、降低内存消耗、支持长连... 目录背景流式返回的核心概念与优势1. 提升用户体验2. 降低内存消耗3. 支持长连接与实时通信在Sp

MySQL JSON 查询中的对象与数组技巧及查询示例

《MySQLJSON查询中的对象与数组技巧及查询示例》MySQL中JSON对象和JSON数组查询的详细介绍及带有WHERE条件的查询示例,本文给大家介绍的非常详细,mysqljson查询示例相关知... 目录jsON 对象查询1. JSON_CONTAINS2. JSON_EXTRACT3. JSON_TA