面试算法-173-二叉树的直径

题目

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

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

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

示例 1:

输入:root = [1,2,3,4,5]

输出:3

解释:3 ,取路径 [4,2,1,3] 或 [5,2,1,3] 的长度。

java 复制代码
class Solution {
    public int diameterOfBinaryTree(TreeNode root) {
        int[] max = { 0 };
        dfs(root, max);
        return max[0];
    }

    public int dfs(TreeNode root, int[] max) {
        if (root == null) {
            return 0;
        }

        int[] maxLeft = { 0 };
        int left = dfs(root.left, maxLeft);
        int[] maxRight = { 0 };
        int right = dfs(root.right, maxRight);

        max[0] = Math.max(maxLeft[0], maxRight[0]);
        max[0] = Math.max(max[0], left + right);

        return Math.max(left, right) + 1;
    }
}
相关推荐
黎阳之光3 分钟前
AI数智筑防线 绿色科技启新篇,如何用硬核技术赋能生态安全双升级
人工智能·科技·算法·安全·数字孪生
2201_758642646 分钟前
自定义内存检测工具
开发语言·c++·算法
前端摸鱼匠10 分钟前
【AI大模型春招面试题9】大模型预训练的核心目标函数(如MLM、NSP、Causal LM)分别是什么?
人工智能·ai·面试·职场和发展·求职招聘
Westward-sun.11 分钟前
矿物分类实战(一):从异常值到标准化——数据清洗全流程拆解
人工智能·算法·机器学习·数据清洗
D_C_tyu20 分钟前
HTML | 结合Canvas开发具有智能寻路功能的贪吃蛇小游戏实战详解
javascript·算法·游戏·html·bfs
小王不爱笑13225 分钟前
HashMap 扩容全流程
java·数据结构·算法
代码探秘者27 分钟前
【算法篇】4.前缀和
java·数据库·后端·python·算法·spring
计算机安禾27 分钟前
【数据结构与算法】第4篇:算法效率衡量:时间复杂度和空间复杂度
java·c语言·开发语言·数据结构·c++·算法·visual studio
Oueii33 分钟前
嵌入式LinuxC++开发
开发语言·c++·算法
sw12138933 分钟前
嵌入式C++驱动开发
开发语言·c++·算法