java 三角形排列_动态规划之Triangle(三角形) Java实现

问题

给定一个三角形的数字阵列,选择一条自顶向下的路径,使得沿途的所有数字之和最小。(每一步只能移动到相邻的格子中)

d0bea202831534c3032ba8f2b9960cdd.png

如上图所示的三角形阵列,其最小路径之和为11(2+3+5+1)。

问题分析

我们对该三角形阵列从最底层求起,用一个result数组存放每一层的数的较小值和其相邻的上面一层的数之和,直到遍历到顶层,返回result[0]。

以本题为例:

1、我们先新建一个result数组,其里面的值都是0,0的较小值还是0,然后遍历其相邻的上面一层的数并求之和,得到result数组中的值为[0+4,0+1,0+8,0+3],即[4,1,8,3]。

2、同理,遍历[4,1,8,3]的较小值和遍历[4,1,8,3]的相邻的上一层的数[6,5,7]之和,得到result数组中的值为[1+6,1+5,3+7],即[7,6,10]。

3、同理,遍历[7,6,10]的较小值和遍历[7,6,10]的相邻的上一层的数[3,4]之和,得到result数组中的值为[6+3,6+4],即[9,10]。

4、同理,遍历[9,10]的较小值和遍历[9,10]的相邻的上一层的数[2]之和,得到result数组中的值为[9+2],即[11]。

5、返回result[0],即11。

java

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值