力扣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)
cpp 复制代码
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,得到边数(直径)
    }
};
相关推荐
JieE2121 天前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2122 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack202 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树2 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2123 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2123 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术3 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦3 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050733 天前
(一)小红的数组操作
算法·编程语言