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; // 返回该节点为根的子树的深度
    }
}
相关推荐
毕设源码-钟学长11 分钟前
【开题答辩全过程】以 个性化电影推荐网站的设计与实现为例,包含答辩的问题和答案
java·spring boot
C++业余爱好者19 分钟前
Power Job 快速搭建 及通信机制介绍
java
YGGP22 分钟前
【Golang】LeetCode 32. 最长有效括号
算法·leetcode
qq_2704900961 小时前
SpringBoot药品管理系统设计实现
java·spring boot·后端
、BeYourself1 小时前
SpringAI-ChatClient Fluent API 详解
java·后端·springai
星辰_mya1 小时前
reids哨兵集群与选主
java·开发语言
BD_Marathon1 小时前
SpringBoot快速入门
java·spring boot·后端
期待のcode1 小时前
Java的多态
java·开发语言
证能量少女2 小时前
2026大专Java开发工程师,考什么证加分?
java·开发语言
FPGAI2 小时前
Java学习之基础概念
java·学习