LeetCode hot100-543 二叉树的直径

复制代码
class Solution {
public:
    int diameterOfBinaryTree(TreeNode* root) {
        ans=0;
        maxdep(root);
        return ans;
    }
private:
    int ans;
    int maxdep(TreeNode* root){
        if(!root) return 0;
        int l=maxdep(root->left);
        int r=maxdep(root->right);
        ans=max(ans,l+r);
        return (l>r?l:r)+1;
    }
};
复制代码
int maxDepth(TreeNode* root) {
    if (!root) return 0;
    return max(maxDepth(root->left), maxDepth(root->right)) + 1;
}

这个返回的是节点数

  • 空节点:0

  • 单节点:1

  • 两层树:2

复制代码
    1
   / \
  2   3
 / \
4   5

对于节点 2:

  • 左子树高度 = 1(节点4)

  • 右子树高度 = 1(节点5)

  • 经过节点2的最长路径 = 左高度 + 右高度 = 1 + 1 = 2(边数)

所以代码中的 l + r 实际上加的是节点数 ,但结果恰好等于边数

复制代码
ans = max(ans, l + r);

因为:

  • l = 左子树的高度(节点数)

  • r = 右子树的高度(节点数)

  • 经过当前节点的路径 = 左子树节点数 + 右子树节点数 = 边数

复制代码
return (l > r ? l : r) + 1;
          ↑              ↑
    孩子最大深度    加上当前节点到孩子的边
  • lr:孩子到他们最深后代的距离(边数)

  • +1:当前节点到孩子的 1 条边

  • 返回值:当前节点到最深后代的距离(边数)

相关推荐
sinat_286945193 小时前
harness engineering
人工智能·算法·chatgpt
少许极端3 小时前
算法奇妙屋(四十三)-贪心算法学习之路10
学习·算法·贪心算法
算法鑫探3 小时前
10个数下标排序:最大值、最小值与平均值(下)
c语言·数据结构·算法·排序算法·新人首发
样例过了就是过了3 小时前
LeetCode热题100 爬楼梯
c++·算法·leetcode·动态规划
IronMurphy3 小时前
【算法三十七】51. N 皇后
算法·深度优先
DoUfp0bgq3 小时前
从直觉到算法:贝叶斯思维的技术底层与工程实现
算法
ThisIsMirror3 小时前
leetcode 452 Arrays.sort()排序整数溢出、Integer.compare(a[1], b[1])成功的问题
算法·leetcode
王老师青少年编程3 小时前
csp信奥赛c++之状压枚举
数据结构·c++·算法·csp·信奥赛·csp-s·状压枚举
wayz113 小时前
数据分析中的异常值处理:MAD
算法·数据挖掘·数据分析