地址:https://leetcode-cn.com/problems/triangle/
给出的数组:
[
[2],
[3,4],
[6,5,7],
[4,1,8,3]
]
这道题主要是查找从上到下最短的路径只和,注意是【和】,那么我们是不是可以自顶向下或者自下而上的对n层中对每个元素与n+1层的元素求和,然后取最小赋值给n的那个元素即可。
class Solution {
/**
* @param Integer[][] $triangle
* @return Integer
*/
function minimumTotal($triangle) {
$height = count($triangle);
for($i = $height -2 ; $i >= 0 ;$i--){
$_size = count($triangle[$i]);
for($j = 0 ; $j< $_size; $j++){
$triangle[$i][$j] += min($triangle[$i+1][$j],$triangle[$i+1][$j+1]);
}
}
return $triangle[0][0];
}
}