LeetCode算法递归类—二叉树中的最大路径和

这篇具有很好参考价值的文章主要介绍了LeetCode算法递归类—二叉树中的最大路径和。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

124. 二叉树中的最大路径和 - 力扣(LeetCode)

题解:

代码:

运行结果:


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

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

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

示例 1:

LeetCode算法递归类—二叉树中的最大路径和,题解,算法,leetcode,职场和发展

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

示例 2:

LeetCode算法递归类—二叉树中的最大路径和,题解,算法,leetcode,职场和发展

输入:root = [-10,9,20,null,null,15,7]
输出:42
解释:最优路径是 15 -> 20 -> 7 ,路径和为 15 + 20 + 7 = 42

提示:

  • 树中节点数目范围是 [1, 3 * 104]
  • -1000 <= Node.val <= 1000

题解:

这道题目要求计算二叉树中路径和最大的路径和,即从任意节点出发、经过任意节点、到达任意节点的路径的和的最大值。

为了解决这个问题,我们可以使用递归的方式来遍历二叉树。对于每个节点,我们需要计算该节点的最大贡献值,即该节点作为路径的一部分时能够提供的最大和。

具体步骤如下:

  1. 创建一个变量 maxSum,用于存储结果,初始值设为负无穷大(Integer.MIN_VALUE)。
  2. 定义一个递归函数 gain(TreeNode root),计算节点的最大贡献值,并在递归过程中更新 maxSum 的值。
  3. 在递归函数中,首先进行终止条件的判断,如果当前节点为空,则直接返回 0。
  4. 分别递归计算左子节点和右子节点的最大贡献值,并将其与 0 取较大值。这是因为当贡献值为负数时,对于路径和的增益为 0。
  5. 计算当前节点的最大路径和,即节点值加上左右子节点的最大贡献值之和。
  6. 将当前节点的最大路径和与 maxSum 进行比较,取较大值更新 maxSum
  7. 返回当前节点的最大贡献值,即节点值加上左右子节点最大贡献值之间的较大值。
  8. 在 maxPathSum 函数中,调用 gain 函数计算根节点的最大贡献值,并返回 maxSum 的值作为结果。

这样,当递归结束时,maxSum 中存储的就是二叉树中路径和最大的路径和。

代码:

class Solution {
    // 存储结果
    int maxSum =Integer.MIN_VALUE;
    public int maxPathSum(TreeNode root) {
        gain(root);
        return maxSum;
    }
    // 计算节点最大贡献值
    public int gain(TreeNode root){
        // 终止条件
        if(root==null) return 0;
        // 递归计算左右子节点最大贡献值(结果为负数不计入)
        int left=Math.max(gain(root.left),0);
        int right=Math.max(gain(root.right),0);

        // 计算该结点的最大路径和
        // 节点最大路径和为该节点的值与该节点左右子节点的最大贡献值
        int max=root.val+left+right;
        //比较该节点的最大路径和与目前值(贪心算法)
        maxSum=Math.max(maxSum,max);

        // 返回该节点最大贡献值
        return root.val+Math.max(left,right);
    }
}

运行结果:

LeetCode算法递归类—二叉树中的最大路径和,题解,算法,leetcode,职场和发展

 文章来源地址https://www.toymoban.com/news/detail-659753.html

到了这里,关于LeetCode算法递归类—二叉树中的最大路径和的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包赞助服务器费用

相关文章

  • 【算法刷题day20】Leetcode:654. 最大二叉树、617.合并二叉树、700. 二叉搜索树中的搜索、98.验证二叉搜索树

    草稿图网站 java的Deque 题目: 654. 最大二叉树 解析: 代码随想录解析 解题思路 NLR的建树 代码 总结 暂无 题目: 617.合并二叉树 解析: 代码随想录解析 解题思路 如果都为root1, root2都为空,返回null;如果root1为空,root2不为空,返回root2;如果roo1不为空,root2为空,返回root

    2024年04月10日
    浏览(16)
  • 算法刷题Day 20 最大二叉树+合并二叉树+二叉搜索树中的搜索+验证二叉搜索树

    递归 递归 迭代 递归 迭代 遇到两个坑的地方: 递归的时候,不能光验证左子树的根节点小于当前根节点,右子树的根节点大于但当前根节点,别忘了左子树上的每一个节点都要求比根节点要小,右子树上的每一个节点都要求比根节点大。 根节点跟左(右)子树中的某一个节

    2024年02月16日
    浏览(10)
  • 【数据结构】二叉树中的递归问题(超详细画图~)

    【数据结构】二叉树中的递归问题(超详细画图~)

    和光同尘_我的个人主页 不管风吹浪打,胜似闲庭信步。 --毛泽东 我本来还说上节难来着,没想到这节更难🥲 不过我既然会了保证xdm也能看懂👍 首先回顾下二叉树的概念 二叉树是由:空树 或者非空树(根节点,根节点的左子树、根节点的右子树)组成的 从概念中可以看出

    2024年02月07日
    浏览(17)
  • 二叉树中序遍历非递归算法C语言实现

    // //  Inordertraverse.c //  二叉树链式存储 // //  Created by 丘** on 2021/7/28. // #include \\\"Inordertraverse.h\\\" #include stdbool.h #includestdlib.h typedef   struct StackNode {     int data;     struct StackNode* next;      }StackNode; typedef struct BiTNode {     int data;     struct BiTNode* lchild,* rchild;           }BiTnode

    2024年02月02日
    浏览(9)
  • 每日一题 1372二叉树中的最长交错路径

    每日一题 1372二叉树中的最长交错路径

    给你一棵以  root  为根的二叉树,二叉树中的交错路径定义如下: 选择二叉树中  任意  节点和一个方向(左或者右)。 如果前进方向为右,那么移动到当前节点的的右子节点,否则移动到它的左子节点。 改变前进方向:左变右或者右变左。 重复第二步和第三步,直到你

    2024年02月10日
    浏览(15)
  • day20 最大的二叉树 合并二叉树 二叉搜索树中的搜索 验证二叉搜索树

    day20 最大的二叉树 合并二叉树 二叉搜索树中的搜索 验证二叉搜索树

    题目链接:654 最大二叉树 题意 根据不重复的整数数组nums构建最大的二叉树 ,根节点是数组中的最大值,最大值左边的子数组构建左子树,最大值右边的子数组构建右子树 nums数组中最少含有1个元素,并且nums中的元素数值均大于等于0 递归  递归三部曲: 1)确定递归函数的

    2024年01月21日
    浏览(9)
  • 假设二叉树中每个结点值为单个字符,采用二叉链存储结构存储。设计一个算法,求二叉树b中第k层上叶子结点个数(非递归算法)。

    int LevelCount(BiTNode *b,int k){         BiTNode *p=b,*temp[Maxsize];         int layer=0,count=0, m=0, n=1; (m: 上一层结点的尾   n: 当层结点的尾 )         temp[0]=NULL;         temp[1]=p;         if(p==NULL) return 0;// 二叉树为空,任意层结点个数均为 0         while(1){          

    2024年02月04日
    浏览(9)
  • 【算法专题】二叉树中的深搜(DFS)

    深度优先遍历(DFS,全称为 Depth First Traversal),是我们树或者图这样的数据结构中常用的⼀种遍历算法。这个算法会尽可能深的搜索树或者图的分支,直到一条路径上的所有节点都被遍历完毕,然后再回溯到上一层,继续找⼀条路遍历。 在二叉树中,常见的深度优先遍历为

    2024年02月03日
    浏览(13)
  • 算法通关村——二分查找在二叉树中的应用

    二叉搜索树中的搜索 给定二叉搜索树(BST)的根节点 root 和一个整数值 val。 你需要在 BST 中找到节点值等于 val 的节点。 返回以该节点为根的子树。 如果节点不存在,则返回 null 。 一开始以为很难,无从下手,但是题目已经规定了这是二叉搜索树,意味着将元素按照中序排

    2024年02月13日
    浏览(7)
  • 设计一个求结点x在二叉树中的双亲结点算法

    要设计一个求二叉树中指定节点 x 的双亲节点的算法,可以按照以下步骤进行: 创建一个递归函数  findParent(root, x) ,其中  root  是当前子树的根节点, x  是要查找其双亲节点的节点。 首先检查根节点是否为空或者根节点是否就是要查找的节点 x,若是,则说明 x 没有双亲

    2024年02月04日
    浏览(9)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包