问题
给定一个三角形的数字阵列,选择一条自顶向下的路径,使得沿途的所有数字之和最小。(每一步只能移动到相邻的格子中)
如上图所示的三角形阵列,其最小路径之和为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