37.二叉树的最大深度

题目链接

给定一个二叉树 root ,返回其最大深度。

二叉树的 最大深度 是指从根节点到最远叶子节点的最长路径上的节点数。

解法1 递归dfs

思路

像二叉树的一些题目都可以用递归的思路去解题。

递归首先想到的是停止条件,如果当前节点没有左右子树,那么深度为 1 直接返回即可。

接下来对左子树和右子树递归计算深度,返回时返回左右子树中最大的高度再加上这一层的高度 1 即可。

代码

js 复制代码
function maxDepth(root: TreeNode | null): number {
    if (!root) {
        return 0;
    }
    if (!root.left && !root.right) {
        return 1;
    }
    const left = root.left ? maxDepth(root.left) : 0;
    const right = root.right ? maxDepth(root.right) : 0;

    return Math.max(left, right) + 1;
};

时空复杂度

时间复杂度:O(n)

空间复杂度:平均O(h)h 是树的高度。最差退化为单链表 栈空间为 O(n)

解法2 层序遍历bfs

思路

将每一层的子节点放入队列中,逐个遍历,最大深度自增。

代码

js 复制代码
function maxDepth(root: TreeNode | null): number {
    if (root === null) return 0;

    let queue: TreeNode[] = [root];
    let depth = 0;

    while (queue.length > 0) {
        const levelSize = queue.length;

        for (let i = 0; i < levelSize; i++) {
            const node = queue.shift()!;
            if (node.left) queue.push(node.left);
            if (node.right) queue.push(node.right);
        }

        depth++;
    }

    return depth;
};

时空复杂度

时间复杂度:O(n)

空间复杂度:O(n)

相关推荐
QUST-Learn3D几秒前
geometry4Sharp Ray-Mesh求交 判断点是否在几何体内部
服务器·前端·数据库
持续升级打怪中16 分钟前
ES6 Promise 完全指南:从入门到精通
前端·javascript·es6
AC赳赳老秦17 分钟前
前端可视化组件开发:DeepSeek辅助Vue/React图表组件编写实战
前端·vue.js·人工智能·react.js·信息可视化·数据分析·deepseek
菜鸟233号18 分钟前
力扣343 整数拆分 java实现
java·数据结构·算法·leetcode
小白冲鸭21 分钟前
苍穹外卖-前端环境搭建-nginx双击后网页打不开
运维·前端·nginx
wulijuan88866622 分钟前
Web Worker
前端·javascript
深念Y23 分钟前
仿B站项目 前端 3 首页 整体结构
前端·ai·vue·agent·bilibili·首页
IT_陈寒24 分钟前
React 18实战:这5个新特性让我的开发效率提升了40%
前端·人工智能·后端
深念Y29 分钟前
仿B站项目 前端 5 首页 标签栏
前端·vue·ai编程·bilibili·标签栏·trae·滚动栏
克里斯蒂亚诺更新35 分钟前
vue3使用pinia替代vuex举例
前端·javascript·vue.js