算法.动态规划 矩阵取数问题 (列表 图 JAVA)

目录

前言

问题

数据结构

计算

附录


前言

矩阵取数问题 其实是 数塔取数问题的变形,类似导航问题

问题

一个N*N矩阵中有不同的正整数,经过这个格子,就能获得相应价值的奖励,从左上走到右下,只能向下向右走,求能够获得的最大价值。例如:3 * 3的方格。

1 3 3

2 1 3

2 2 1

能够获得的最大价值为:11。

数据结构

图:

代码:

	// 初始化
	public ListNode initData(){

		/**
		 *      1
		 *   2     3
		 * 2    1     3
		 *   2     3
		 *      1
		 */
		ListNode data40 = new ListNode(1);
		
		ListNode data30 = new ListNode(2,null,data40);
		ListNode data31 = new ListNode(3,data40,null);
	
		ListNode data20 = new ListNode(2,null,data30);
		ListNode data21 = new ListNode(1,data30,data31);
		ListNode data22 = new ListNode(3,data31,null);
		
		ListNode data10 = new ListNode(2,data20,data21);
		ListNode data11 = new ListNode(3,data21,data22);

		ListNode data00 = new ListNode(1,data10,data11);

		minData(data00);

		return data00;
	}

	// 树节点
	public class ListNode {
		int value;
		int pathValue;
		ListNode left;
		ListNode right;
		ListNode() {}
		ListNode(int value) { 
			this.value = value; 
		}
		ListNode(int value, ListNode left,ListNode right) { 
			this.value = value; 
			this.left = left;
			this.right = right;
		}
	}

计算

data.pathValue = data.value +  Math.max(minData(data.left) , minData(data.right));

如果是导航问题,这里应该是最短距离

	@Test
	public void test1(){

		// 初始化数组
		ListNode data = initData();

		// 计算pathValue
		minData(data);
		
		System.out.println("最小值为:" + data.pathValue);
	}

	private int minData(ListNode data){
		if(data == null){
			return 0;
		}
		data.pathValue = data.value +  Math.max(minData(data.left) , minData(data.right));
		return data.pathValue;
	}

附录

思想参考:动态规划 解决导航/数塔取数字问题_要钱也要自我实现-CSDN博客不用动脑理解动态规划,分治思想https://blog.csdn.net/weixin_42754896/article/details/122998854

代码参考:【算法】JAVA实现 数塔取数问题(列表版)_要钱也要自我实现-CSDN博客前言上一篇说了动态规划思想和思路,现在实现代码,存储不同,思想可能相同,但代码结构可能大不一样。动态规划 解决导航/数塔取数字问题_要钱也要自我实现-CSDN博客问题如下数塔,求:计算出三角形的由顶至底的一条路径,使该路径经过的数字总和最小。数据来源:java动态规划问题 - my日常work - 博客园备注:上图 只是示例,跟实际用的数据有差异。存储 7 3  8 8  1  0 2  7  4  44  5  2  https://blog.csdn.net/weixin_42754896/article/details/123004314


end

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

闲猫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值