题目描述:
给定一个非空二叉树,返回其最大路径和。
本题中,路径被定义为一条从树中任意节点出发,达到任意节点的序列。该路径至少包含一个节点,且不一定经过根节点。
示例 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.valvar 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的用法还不是很熟悉,需要多练习。
