★543. 二叉树的直径

543. 二叉树的直径

简单题,确实不难。

相当于就是求节点的深度。左孩子的最大深度 + 右孩子的最大深度 + 1 = 根节点深度。

本题要求的就是路径数,这里的路径数 = 节点数 - 1,然后想一下,对于一个节点来说,以他为根左右两边两边最长路径就是左孩子深度 + 右孩子深度。(这里的路径等于根节点深度 - 1嘛)

所以就是跑一个求深度的递归,然后每次都更新一下以当前节点为根的左右孩子深度和。

这个左右孩子的深度和就是所要求的路径长度。再 + 1 就是经过的节点个数,即以当前节点为根的深度。

java 复制代码
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    int max = 0;
    public int diameterOfBinaryTree(TreeNode root) {
        depth(root);
        return max;
    }
    public int depth(TreeNode root){
        if(root == null) return 0;
        int left = depth(root.left);
        int right = depth(root.right);
        if(max < left + right)      //这里这个max就是不加上根节点的节点个数,也等于路径个数。
            max = left + right;
        return Math.max(left, right) + 1;
    }
}
相关推荐
Ttang233 小时前
Leetcode:118. 杨辉三角——Java数学法求解
算法·leetcode
路遇晚风3 小时前
力扣=Mysql-3322- 英超积分榜排名 III(中等)
mysql·算法·leetcode·职场和发展
木向3 小时前
leetcode104:二叉树的最大深度
算法·leetcode
一个不喜欢and不会代码的码农3 小时前
力扣113:路径总和II
算法·leetcode
向阳12183 小时前
LeetCode40:组合总和II
java·算法·leetcode
旧日之血_Hayter3 小时前
LeetCode297.二叉树的序列化和反序列化
算法·leetcode
Wils0nEdwards3 小时前
Leetcode 整数转罗马数字
linux·python·leetcode
Star Patrick3 小时前
算法训练(leetcode)二刷第二十六天 | *452. 用最少数量的箭引爆气球、435. 无重叠区间、*763. 划分字母区间
算法·leetcode·哈希算法
simple_ssn7 小时前
【C语言刷力扣】1502.判断能否形成等差数列
c语言·算法·leetcode
Curry_Math7 小时前
LeetCode 热题100之技巧关卡
算法·leetcode