力扣 二叉树 104. 二叉树的最大深度

104. 二叉树的最大深度

一、题目描述

二、理解

对照二叉树的递归定义:

  • 如果树为空,则它是一个空树。
  • 如果树不为空,它由一个根节点和两个子树组成,分别是左子树和右子树,且左子树和右子树本身也是二叉树。
    采用递归形式解决问题:
  • 首先判断 root 是否 null,若为 null,则该树的的深度为0。
  • 若 root 不为 null,则该树的最大深度为,max (左子树的最大深度, 右子树最大深度) + 1。

三、代码

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 {
    public int maxDepth(TreeNode root) {
        if (root == null) {
            return 0;
        }
        int leftDepth = maxDepth(root.left);
        int rightDepth = maxDepth(root.right);
        return Math.max(leftDepth, rightDepth) + 1;
    }
}
相关推荐
代码探秘者16 分钟前
【算法】吃透18种Java 算法快速读写模板
数据结构·数据库·python·算法·spring
2301_8166512216 分钟前
C++模块化设计原则
开发语言·c++·算法
gaozhiyong081317 分钟前
提示词的解剖学:Gemini 3.1 Pro 提示工程高级策略与国内实战
人工智能·算法·机器学习
studyForMokey30 分钟前
【Android面试】Gradle专题
android·面试·职场和发展
小范自学编程38 分钟前
算法训练营Day44 - 动态规划part12
算法·动态规划
。。,……~38 分钟前
RGB-IR融合算法CDDFUSE理解+复现
算法
小刘的AI小站40 分钟前
L9 Policy Gradient Method (二)
算法·机器学习·强化学习
WolfGang0073211 小时前
代码随想录算法训练营 Day21 | 回溯算法 part03
数据结构·算法
tankeven1 小时前
HJ152 取数游戏
c++·算法
程序员Shawn1 小时前
【机器学习 | 第六篇】- 机器学习
人工智能·算法·机器学习·集成学习