543.二叉树的直径

给你一棵二叉树的根节点,返回该树的 直径

二叉树的 直径 是指树中任意两个节点之间最长路径的 长度 。这条路径可能经过也可能不经过根节点 root

两节点之间路径的 长度 由它们之间边数表示。

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 ans = 0;
    public int diameterOfBinaryTree(TreeNode root) {
        dfs(root);
        return ans;
    }
    public int dfs(TreeNode node) {
        if ( node == null) {
            return -1; // dfs(null) + 1 = 0 这样空节点的左右链长都是为0
        }

        int leftLen = dfs(node.left) + 1; // 左子树最大链长 + 1
        int rightLen = dfs(node.right) + 1; // 右子树最大链长 + 1
        ans = Math.max(ans, leftLen + rightLen); // 两条链拼成路径
        return Math.max(leftLen, rightLen);  // 当前子树最大链长
    }
}
相关推荐
田梓燊1 天前
力扣:23.合并 K 个升序链表
算法·leetcode·链表
invicinble1 天前
这里对java的知识体系做一个全域的介绍
java·开发语言·python
wbs_scy1 天前
【Linux 线程进阶】进程 vs 线程资源划分 + 线程控制全详解
java·开发语言
re林檎1 天前
算法札记——4.27
算法
ss2731 天前
食谱推荐系统功能测试如何写?
java·数据库·spring boot·功能测试
AI人工智能+电脑小能手1 天前
【大白话说Java面试题】【Java基础篇】第15题:JDK1.7中HashMap扩容为什么会发生死循环?如何解决
java·开发语言·数据结构·后端·面试·哈希算法
数据牧羊人的成长笔记1 天前
逻辑回归与Softmax回归
算法·回归·逻辑回归
try2find1 天前
打印ascii码报错问题
java·linux·前端
014-code1 天前
CompletableFuture 实战模板(超时、组合、异常链处理)
java·数据库
Nicander1 天前
多数据源下@transcation事务踩坑
java·后端