题目描述:
给定一个非空二叉树,返回其最大路径和。
本题中,路径被定义为一条从树中任意节点出发,达到任意节点的序列。该路径至少包含一个节点,且不一定经过根节点。
示例 1:
输入: [1,2,3]
1
/ \
2 3
输出: 6
示例 2:
输入: [-10,9,20,null,null,15,7]
-10
/ \
9 20
/ \
15 7
输出: 42
算法实现:
/**
* Definition for a binary tree node.
* function TreeNode(val) {
* this.val = val;
* this.left = this.right = null;
* }
*/
/**
* @param {TreeNode} root
* @return {number}
*/
var maxPathSum = function(root) {
var maxVal = root.val
var getMaxVal = function(root) {
if (!root) {
return 0
}
var leftMax = getMaxVal(root.left)
var rightMax = getMaxVal(root.right)
var maxCountBoth = Math.max(root.val, root.val + leftMax, root.val + rightMax, root.val + rightMax + leftMax)
var maxCountSingle = Math.max(root.val, root.val + leftMax, root.val + rightMax)
maxVal = Math.max(maxVal,maxCountBoth)
return maxCountSingle
}
getMaxVal(root)
return maxVal
};
思考:
总结:
对于val的用法还不是很熟悉,需要多练习。