LeetCode刷题笔记 Java 腾讯 链表突击 二叉树中的最大路径和

题目

官解

=========================================================================

路径 被定义为一条从树中任意节点出发,沿父节点-子节点连接,达到任意节点的序列。同一个节点在一条路径序列中 至多出现一次 。该路径 至少包含一个 节点,且不一定经过根节点。

路径和 是路径中各节点值的总和。

给你一个二叉树的根节点 root ,返回其 最大路径和 。

LeetCode刷题笔记 Java 腾讯 链表突击 二叉树中的最大路径和_第1张图片

 

递归

maxGain返回的是包含当前结点一条路径的最大值-主要用于父节点求解

左节点maxGain 右节点maxGain 为maxGain和0对比求大值即保证始终大于0

其中priceNewpath返回的是左节点maxGain+右节点maxGain+根节点,即三角形路径的值

每次递归过程如果priceNewpath比maxSum大 则更新maxSum

maxSum为最终结果

class Solution {
    int maxSum = Integer.MIN_VALUE;

    public int maxPathSum(TreeNode root) {
        maxGain(root);
        return maxSum;
    }

    public int maxGain(TreeNode node) {
        if (node == null) {
            return 0;
        }
        
        // 递归计算左右子节点的最大贡献值
        // 只有在最大贡献值大于 0 时,才会选取对应子节点
        int leftGain = Math.max(maxGain(node.left), 0);
        int rightGain = Math.max(maxGain(node.right), 0);

        // 节点的最大路径和取决于该节点的值与该节点的左右子节点的最大贡献值
        int priceNewpath = node.val + leftGain + rightGain;

        // 更新答案
        maxSum = Math.max(maxSum, priceNewpath);

        // 返回节点的最大贡献值
        return node.val + Math.max(leftGain, rightGain);
    }
}

你可能感兴趣的:(LeetCode,链表,java,leetcode)