算法.动态规划.数塔取数问题(列表版,JAVA实现)

前言

上一篇说了动态规划思想和思路,现在实现代码,存储不同,思想可能相同,但代码结构可能大不一样。

动态规划 解决导航/数塔取数字问题_要钱也要自我实现-CSDN博客

问题

如下数塔,求:计算出三角形的由顶至底的一条路径,使该路径经过的数字总和最小。

数据来源:java动态规划问题 - my日常work - 博客园

备注:上图 只是示例,跟实际用的数据有差异。

存储

  		    7

		  3  8

	    8  1  0

	  2  7  4  4

	4  5  2  6  5

代码:

	// 初始化树
	public ListNode initData(){

		/**
		 * 		    7
		
				  3  8
		
			    8  1  0
		
			  2  7  4  4
		
			4  5  2  6  5
		 */
		ListNode data40 = new ListNode(4);
		ListNode data41 = new ListNode(5);
		ListNode data42 = new ListNode(2);
		ListNode data43 = new ListNode(6);
		ListNode data44 = new ListNode(5);
		
		ListNode data30 = new ListNode(2,data40,data41);
		ListNode data31 = new ListNode(7,data41,data42);
		ListNode data32 = new ListNode(4,data42,data43);
		ListNode data33 = new ListNode(4,data43,data44);
	
		ListNode data20 = new ListNode(8,data30,data31);
		ListNode data21 = new ListNode(1,data31,data32);
		ListNode data22 = new ListNode(0,data32,data33);
		
		ListNode data10 = new ListNode(3,data20,data21);
		ListNode data11 = new ListNode(8,data21,data22);

		ListNode data00 = new ListNode(7,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.min(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.min(minData(data.left) , minData(data.right));
		return data.pathValue;
	}

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、付费专栏及课程。

余额充值