当前位置: 首页 > news >正文

leetcode0124. 二叉树中的最大路径和-hard

1 题目:二叉树中的最大路径和

官方标定难度:难

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

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

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

示例 1:

在这里插入图片描述

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

示例 2:

在这里插入图片描述

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

提示:

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

2 solution

可以采用树上 dp ,计算每一个节点到左右子树的最大路径,如果最大值大于零,那么上一层就会用到这些点,否则就是单个根节点。

代码

class Solution {int M = -1000;int dfs(TreeNode *root) {if (!root) {return 0;}int a = root->val;int b = a;int l = dfs(root->left);int r = dfs(root->right);if (l > 0) a += l;if (r > 0) b += r;M = max(M, a + b - root->val);return max(a, b);}public:int maxPathSum(TreeNode *root) {dfs(root);return M;}
};

结果

在这里插入图片描述

http://www.xdnf.cn/news/92539.html

相关文章:

  • Python实例题:Python3OpenCV视频转字符动画
  • AI编程助手Cline之快速介绍
  • 人形机器人技术发展与未来趋势
  • 创建redis-cluster集群
  • 2023蓝帽杯初赛内存取证-2
  • ISO15189认证有什么要求?ISO15189认证流程
  • STM32的定时器输出PWM时,死区时间(DTR)如何计算
  • 报错:sudo:./VMware-workstation-Ful1-16.2.3-19376536.x86 64.bundle:找不到命令
  • 自定义UI组件库之组件及属性提示功能
  • C语言高频面试题目——内联函数和普通函数的区别
  • echarts模板化开发,简易版配置大屏组件-根据配置文件输出图形和模板(vue2+echarts5.0)
  • 类与对象(上)
  • 网络应用程序体系结构
  • 【阿里云大模型高级工程师ACP习题集】2.2 扩展答疑机器人的知识范围
  • 跨平台.NET 版本 使用率排名
  • JavaFX 实战:从零打造一个功能丰富的英文“刽子手”(Hangman)游戏
  • 鸿道Intewell操作系统助力工业机器人控制系统自主可控
  • PowerBi中ALLEXCEPT怎么使用?
  • Linux 网络编程:select、poll 与 epoll 深度解析 —— 从基础到高并发实战
  • Python 获取淘宝买家订单详情(buyer_order_detail)接口的详细指南
  • 【CPP】固定大小内存池
  • Java高并发下分布式缓存和数据库一致性解决方案
  • 【文件上传/下载Java+vue3——MQ】
  • [Java · 铢积寸累] 数据结构 — 数组类型 - 增 删 改 查
  • 逻辑回归:使用 S 型函数进行概率预测
  • VMwaer虚拟机复制粘贴、ROS系统安装
  • 武装Burp Suite工具:HaE 分析辅助类_插件.【高亮标记和信息提取利器】
  • C++算法(13):如何高效读取并存储未知数量的空格分隔数字
  • 资本怪兽贝莱德投资数据分析报告-独家
  • 具有相同数量的置位(1位)的下一个更大数字