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

力扣HOT100(45) 二叉树的直径

任意一条路径,都可以看作是以某个节点为 “拐点”,左边接左子树的最深路径,右边接右子树的最深路径。

比如路径4→2→1→3的拐点是节点 1:

  • 左子树最深路径:1→2→4(2 条边)
  • 右子树最深路径:1→3(1 条边)
  • 总路径长度:2+1=3(边数)

所以我们的目标转化为:

  1. 遍历树中所有节点,计算每个节点作为 “拐点” 时的路径长度;
  2. 取所有路径长度的最大值,就是整棵树的直径

完整解题步骤

1. 定义两个核心变量

  • depth(node):递归函数,返回以node为根的子树的深度(节点数)
  • ans:全局变量,记录所有节点作为拐点时,路径经过的节点数最大值

2. 递归函数depth(node)的逻辑

  1. 终止条件:如果node是空节点,返回 0(空树深度为 0)
  2. 递归左子树:得到左子树深度L
  3. 递归右子树:得到右子树深度R
  4. 更新最大值:当前节点作为拐点的路径节点数 =L + R + 1(+1 是加上当前节点本身),用这个值更新ans
  5. 返回当前子树深度max(L, R) + 1(当前节点 + 左右子树中更深的那个)

3. 主函数逻辑

  1. 初始化ans = 1(至少有一个节点,路径节点数为 1)
  2. 调用depth(root)遍历整棵树
  3. 最终直径 =ans - 1(因为边数 = 节点数 - 1)
class Solution { int ans; // 全局变量:记录所有路径的节点数最大值 // 递归函数:返回以rt为根的子树的深度(节点数) int depth(TreeNode* rt){ // 1. 终止条件:空节点,深度为0 if (rt == NULL) { return 0; } // 2. 先算左子树深度 int L = depth(rt->left); // 3. 再算右子树深度 int R = depth(rt->right); // 4. 关键:计算当前节点作为拐点的路径节点数,更新最大值 ans = max(ans, L + R + 1); // 5. 返回当前子树的深度:左右子树中更深的那个 + 当前节点 return max(L, R) + 1; } public: int diameterOfBinaryTree(TreeNode* root) { ans = 1; // 初始化为1,对应只有一个节点的情况 depth(root); // 遍历整棵树 return ans - 1; // 节点数最大值减1,得到边数(直径) } };
http://www.gsyq.cn/news/1435094.html

相关文章:

  • 别再为OnlyOffice离线安装头疼了!这份CentOS 7保姆级配置清单请收好
  • 基于内存补丁技术的Windows即时通讯软件消息保留解决方案深度解析
  • 酱料代加工选购指南:如何找到高性价比靠谱厂家 - 资讯纵览
  • 日志字段解密全图谱,覆盖user_agent、x-forwarded-for、request_id等12个关键字段的语义还原与误判规避手册
  • 2026 深圳 GEO 优化机构实力排行:全意图服务标杆与优质服务商深度解读 - GEO优化
  • Arduino红外遥控库终极指南:15分钟从零掌握智能遥控开发
  • 上海黄金回收店铺联系方式推荐SS级耀辉 - 奢侈品回收
  • Obsidian PDF导出终极指南:如何用Better Export PDF插件解决中文排版难题
  • 跨越语言壁垒:让MASA模组系列为中文玩家点亮创意之光
  • 2026 全球 GEO 优化服务商权威榜单:全意图 GEO 领军者与五强机构综合盘点 - GEO优化
  • Arduino记忆游戏实战:从硬件设计到状态机编程全解析
  • 微信数据管理终极指南:如何安全导出并永久保存聊天记录
  • Tinkercad仿真Arduino温湿度监控:从虚拟电路到物联网闭环实践
  • 基于树莓派DIY室内空气质量监测系统:从传感器选型到智能控制
  • 2026 北京 GEO 优化机构实力榜单:全意图服务标杆与本地优质服务商盘点 - GEO优化
  • 微信聊天记录永久保存完全指南:让珍贵对话成为你的数字资产
  • 基于ESP8266与Alexa的智能灯光控制系统DIY全攻略
  • 矿山做业实时监测透明化三维立体重构视频孪生数字孪生安全治理
  • 杭州绿映园艺:滨江口碑好的绿植租赁电话 - LYL仔仔
  • 揭秘图片中的隐藏世界:终极在线隐写分析工具完全指南
  • SQLite 数据类型
  • 5分钟永久备份QQ空间所有历史说说:GetQzonehistory完整使用指南
  • 基于Arduino的智能植物自动浇水系统:从传感器到执行器的闭环控制实践
  • 基于Arduino与PN532的多节点RFID交互系统设计与实现
  • 2026年京东云OpenClaw/Hermes Agent配置Token Plan安装步骤全解
  • 微信聊天记录永久保存终极指南:WeChatMsg完整免费解决方案
  • 2026年6月重磅推荐|卡地亚中国官方售后网络2026焕新升级公告 - 卡地亚服务中心
  • Arduino水位监测:模拟传感器分级报警系统DIY指南
  • 如何在Windows 11上体验经典Windows任务栏的怀旧魅力?
  • OpCore Simplify:5步快速创建完美黑苹果EFI的终极指南