124. 二叉树中的最大路径和

72 阅读1分钟
class Solution {
   private int ans = Integer.MIN_VALUE;
    public int maxPathSum(TreeNode root) {
        dfs(root);
        return ans;
    }

    private int dfs(TreeNode root) {
        if (root == null) {
            return 0;
        }
        int left = dfs(root.left);
        int right = dfs(root.right);
        //更新穿过当前根结点的最大路径
        ans = Math.max(ans, left + right + root.val);
        ////如果左子树或者右子树的路径和小于0则不选择该路径。即路径和为0
        return Math.max(0, Math.max(left, right) + root.val);
    }
}