124 二叉树中的最大路径和

又是一个hard题目,其实我大概有想到要去dfs遍历节点,当时不知道怎么从一个叶子结点开始遍历。其实只需要从根节点出发,看看左右节点加在一起是否最大能不能作为一个路径,但是对外这是要不左节点上来要不右节点上来,不能两个结点都上来要不然会重复

题目

二叉树中的 路径 被定义为一条节点序列,序列中每对相邻节点之间都存在一条边。同一个节点在一条路径序列中 至多出现一次 。该路径 至少包含一个 节点,且不一定经过根节点。

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

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

示例 1:

ini 复制代码
输入: root = [1,2,3]
输出: 6
解释: 最优路径是 2 -> 1 -> 3 ,路径和为 2 + 1 + 3 = 6

代码与解析

代码上有注释,详细的思路解答

java 复制代码
class Solution {
    int maxSum = Integer.MIN_VALUE; // 用于记录最大路径和

    /**
     * 计算二叉树中任意节点的最大路径和
     * @param root 给定的二叉树根节点
     * @return 返回最大路径和
     */
    public int maxPathSum(TreeNode root) {
        // 如果树只有一个节点,则直接返回该节点的值
        if(root.left == null && root.right == null) return root.val;

        // 调用深度优先搜索方法
        dfs(root);

        return maxSum;
    }

    /**
     * 深度优先搜索计算路径和
     * @param node 当前节点
     * @return 返回当前节点向下路径和的最大值
     */
    public int dfs(TreeNode node) {
        if(node == null) return 0; // 空节点返回0

        int l = Math.max(dfs(node.left), 0); // 左子树提供的最大路径和,负值设为0
        int r = Math.max(dfs(node.right), 0); // 右子树提供的最大路径和,负值设为0

        int innerMax = l + r + node.val; // 当前子树内部的最大路径和
        maxSum = Math.max(maxSum, innerMax); // 更新最大路径和

        int outSum = node.val + Math.max(0, Math.max(l, r)); // 当前节点向上提供的最大路径和
        return outSum < 0 ? 0 : outSum; // 若对外提供的路径和为负,返回0;否则返回路径和
    }
}
相关推荐
艾伦~耶格尔2 小时前
Spring Boot 三层架构开发模式入门
java·spring boot·后端·架构·三层架构
man20172 小时前
基于spring boot的篮球论坛系统
java·spring boot·后端
攸攸太上2 小时前
Spring Gateway学习
java·后端·学习·spring·微服务·gateway
罗曼蒂克在消亡3 小时前
graphql--快速了解graphql特点
后端·graphql
潘多编程3 小时前
Spring Boot与GraphQL:现代化API设计
spring boot·后端·graphql
大神薯条老师3 小时前
Python从入门到高手4.3节-掌握跳转控制语句
后端·爬虫·python·深度学习·机器学习·数据分析
2401_857622664 小时前
Spring Boot新闻推荐系统:性能优化策略
java·spring boot·后端
知否技术4 小时前
为什么nodejs成为后端开发者的新宠?
前端·后端·node.js
AskHarries5 小时前
如何优雅的处理NPE问题?
java·spring boot·后端
计算机学姐5 小时前
基于SpringBoot+Vue的高校运动会管理系统
java·vue.js·spring boot·后端·mysql·intellij-idea·mybatis