Java | Leetcode Java题解之第543题二叉树的直径

题目:

题解:

java 复制代码
class Solution {
    int ans;
    public int diameterOfBinaryTree(TreeNode root) {
        ans = 1;
        depth(root);
        return ans - 1;
    }
    public int depth(TreeNode node) {
        if (node == null) {
            return 0; // 访问到空节点了,返回0
        }
        int L = depth(node.left); // 左儿子为根的子树的深度
        int R = depth(node.right); // 右儿子为根的子树的深度
        ans = Math.max(ans, L+R+1); // 计算d_node即L+R+1 并更新ans
        return Math.max(L, R) + 1; // 返回该节点为根的子树的深度
    }
}
相关推荐
v_for_van几秒前
力扣刷题记录6(无算法背景,纯C语言)
c语言·算法·leetcode
014-code几秒前
Redisson 常用技巧
java·redis
java干货1 分钟前
明明删了数据,磁盘却满了?
java
之歆1 分钟前
HA 高可用集群指南
java·开发语言
样例过了就是过了41 分钟前
LeetCode热题100 最大子数组和
数据结构·算法·leetcode
CHANG_THE_WORLD1 小时前
指针入门一
java·前端·网络
时艰.1 小时前
订单系统读写分离方案设计与实现
java
014-code1 小时前
MySQL 事务隔离级别
java·数据库·mysql
踩坑记录1 小时前
leetcode hot100 200. 岛屿数量 medium dfs
leetcode·深度优先
hrhcode1 小时前
【Netty】三.ChannelPipeline与ChannelHandler责任链深度解析
java·后端·spring·springboot·netty