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; // 返回该节点为根的子树的深度
    }
}
相关推荐
fanzhonghong3 小时前
javaWeb开发之Maven高级
java·开发语言·spring boot·spring cloud·私服
洛水水3 小时前
【力扣100题】26. 二叉树的中序遍历
算法·leetcode·深度优先
sheeta19983 小时前
LeetCode 每日一题笔记 日期:2026.05.11 题目:2553. 分割数组中数字的数位
笔记·算法·leetcode
xu_ws3 小时前
spring通过三级缓存解决循环依赖
java·spring·缓存·循环依赖
Chase_______3 小时前
Java 基础语言 ③:流程控制与数组——从条件分支到数组遍历,一篇通关
java·数据库·python
luck_bor3 小时前
Lambda表达式 算法异常
java·开发语言
码上小翔哥3 小时前
Jackson 配置深度解析
java·后端
qq_2518364573 小时前
基于java 私厨美食共享平台系统设计与实现(有源码)
java·开发语言·美食
未秃头的程序猿3 小时前
如何用 AI 写出符合规范的 Java 代码?我总结了 7 条有效建议
java·后端·ai编程
kyle~3 小时前
Linux时间系统1 --- 正确使用时间
java·linux·服务器