题解 | 二叉树的最大路径和

二叉树的最大路径和

http://www.nowcoder.com/practice/da785ea0f64b442488c125b441a4ba4a

分析

读题:

  • 题目难点在于正确理解题意

  • 一棵二叉树

  • 注意题目对路径的定义:开始和结束结点可以是任意的结点。

  • 路径要求唯一,不能重复

  • 任意给出一棵二叉树的两个结点,路径指的是:分别从这两个结点向上走,找到 最近的公共祖先 结点而形成的路径。只有这样的定义下,路径才是唯一确定的。

考虑如下路径:
图片说明

下图,带X的部分路径表示不符合条件

图片说明

解法一:DFS(递归)

思路步骤:

  • 声明int ans = Integer.MIN_VALUE存储答案

  • DFS计算每一个结点的贡献值

  • 由于路径唯一,在回溯时,只需要取某个父节点的俩孩子结点中的最大者。

  • 对于某个节点,它关心自己走入一个子树,能从中捞取的最大收益,先不用管具体怎么走。

  • 定义dfs函数:返回当前子树能向父节点“提供”的最大路径和。即,一条从父节点延伸下来的路径,能在当前子树中获得的最大收益。分为三种情况:

    • 路径停在当前子树的根节点,在这个子树中贡献:root.val
    • 走入左子树,在这个子树中的最大贡献:root.val + dfs(root.left)
    • 走入右子树,在这个子树中的最大贡献:root.val + dfs(root.right)
  • 对应了前面所讲的三种选择,最大贡献取三者最大:
    即:root.val+max(dfs(root.left),dfs(root.right))

Java参考代码:

import java.util.*;

/*
 * public class TreeNode {
 *   int val = 0;
 *   TreeNode left = null;
 *   TreeNode right = null;
 * }
 */

public class Solution {
    /**
     * 
     * @param root TreeNode类 
     * @return int整型
     */
    int ans = Integer.MIN_VALUE;
    public int maxPathSum (TreeNode root) {
        // write code here

        if(root==null){
            return 0;
        }
        dfs(root);
        return ans;
    }
    //DFS函数
    public int dfs(TreeNode root){
        if(root==null){
            return 0;
        }
        //计算左孩子贡献
        int leftMax = Math.max(dfs(root.left),0);
        //计算右孩子贡献
        int rightMax = Math.max(dfs(root.right),0);
        //更新答案
        ans = Math.max(ans,root.val+leftMax+rightMax);
      

剩余60%内容,订阅专栏后可继续查看/也可单篇购买

小白专属-牛客题解 文章被收录于专栏

专注于牛客平台编程题题解,文字+图解。内容很细,小白友好系列

全部评论
题目不是也要求空间复杂度是O(1)吗?
点赞 回复 分享
发布于 2022-02-09 09:19

相关推荐

找工作勤劳小蜜蜂:自我描述部分太差,完全看不出想从事什么行业什么岗位,也看不出想在哪个地区发展,这样 会让HR很犹豫,从而把你简历否决掉。现在企业都很注重员工稳定性和专注性,特别对于热爱本行业的员工。 你实习的工作又太传统的it开发(老旧),这部分公司已经趋于被淘汰,新兴的互联网服务业,比如物流,电商,新传媒,游戏开发和传统的It开发有天然区别。不是说传统It开发不行,而是就业岗位太少,基本趋于饱和,很多老骨头还能坚持,不需要新血液。 工作区域(比如长三角,珠三角,成渝)等也是HR考虑的因素之一,也是要你有个坚定的决心。否则去几天,人跑了,HR会被用人单位骂死。
点赞 评论 收藏
分享
压力很大,面试官全程高压,问的问题不难,但是没有任何反馈,很慌张,也无算法。实习问了20分钟,一直问我你们做的有什么用,总时长一小时1.学校都有什么课程2.spring的ioc原理以及优点3.除了解耦还知道什么?4.springboot与spring区别,二者的源码看过没?Tomcat了解嘛?有没有具体看过5.spring的bean,面试官一直在重复一个思想问我懂不懂,完全没听过6.mybatis是干什么的?ibatis用过没?平常怎么写SQL?完全不写嘛?7.设计一个分布式双十一秒杀系统(前端,网关,缓存,数据库防超卖全设计)8.怎么做限流9.缓存与数据库一致性,你做异步要用户等你嘛?10.负载均衡怎么做11.多数据中心还是单数据中心,如果出现没卖完怎么做(到这完全不会了,面试官直接说换个话题吧)12.平常读书吗?13.上过哲学课嘛?14.兴趣爱好有没有15.对ai的看法16.来深圳有问题嘛?17.为什么不考研18.上大学带给了你什么?你提升在哪里,有没有具体的例子?反问:1.现在手机都有应用市场,应用宝怎么盈利?除了手机应用市场还是有人用,现在在做跨端,微软都有合作,之后会进军mac,主要做游戏,腾讯本身就是游戏大户。2.面试表现?整体评价一下会给到反馈。面完直接变HR面,今天HR面后,已经转为录用评估了,来牛客许个愿,暑期现在还没什么面试,希望能拿个offer之后再考虑要不要留在手子吧。
nunuking:三面压力这么大吗,面试的会议约了多长时间呀
面试问题记录
点赞 评论 收藏
分享
评论
4
1
分享

创作者周榜

更多
正在热议
更多
# 一张图晒出你司的标语 #
4251次浏览 75人参与
# AI面会问哪些问题? #
27505次浏览 550人参与
# 开放七大实习专项,百度暑期实习值得冲吗 #
15084次浏览 221人参与
# 你的实习产出是真实的还是包装的? #
20041次浏览 342人参与
# 找AI工作可以去哪些公司? #
8935次浏览 230人参与
# 春招至今,你的战绩如何? #
64488次浏览 575人参与
# 米连集团26产品管培生项目 #
13291次浏览 285人参与
# 从事AI岗需要掌握哪些技术栈? #
8791次浏览 299人参与
# 你做过最难的笔试是哪家公司 #
33064次浏览 229人参与
# 中国电信笔试 #
31910次浏览 292人参与
# 投递几十家公司,到现在0offer,大家都一样吗 #
340695次浏览 2173人参与
# 哪些公司真双非友好? #
69552次浏览 289人参与
# 阿里笔试 #
178352次浏览 1314人参与
# 机械人避雷的岗位/公司 #
62693次浏览 393人参与
# 第一份工作一定要去大厂吗 #
14405次浏览 122人参与
# 金三银四,你的春招进行到哪个阶段了? #
22047次浏览 280人参与
# 为了减少AI幻觉,你注入过哪些设定? #
26231次浏览 310人参与
# 沪漂/北漂你觉得哪个更苦? #
9748次浏览 193人参与
# HR最不可信的一句话是__ #
6151次浏览 113人参与
# 应届生第一份工资要多少合适 #
20663次浏览 86人参与
# AI时代,哪个岗位还有“活路” #
11419次浏览 339人参与
# 春招你拿到offer了吗 #
831079次浏览 9986人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务