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

给定一个二叉树 root ,返回其最大深度。
二叉树的 最大深度 是指从根节点到最远叶子节点的最长路径上的节点数。



提示:

  • 树中节点的数量在 [0, 104] 区间内。
  • -100 <= Node.val <= 100

代码:

cpp 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
    int maxDepth(TreeNode* root) {
        int right_depth, left_depth;
        
        if(root == nullptr){
            return 0;
        }

        right_depth = maxDepth(root->right) + 1;

        left_depth = maxDepth(root->left) + 1;

        return max(right_depth, left_depth);
    }
};

解题思路:

(1)使用递归思想。

(2)分别递归左右子树,每次递归就把深度+1。

(3)最后,比较左右子树深度,输出最大值。

相关推荐
盼海6 分钟前
排序算法(六)--堆排序
java·算法·排序算法
叫我:松哥9 分钟前
基于python flask的网页五子棋实现,包括多种语言,可以悔棋、重新开始
开发语言·python·算法·游戏·flask
陈序缘12 分钟前
Rust 力扣 - 198. 打家劫舍
开发语言·后端·算法·leetcode·rust
凭君语未可15 分钟前
豆包MarsCode算法题:三数之和问题
java·算法
苏言の狗1 小时前
CCF认证202406-01 | 矩阵重塑(其一)
c语言·数据结构·c++·算法·矩阵
@大嘴巴子1 小时前
从入门到精通数据结构----四大排序(上)
数据结构·算法·排序算法
_GR2 小时前
每日OJ_牛客_游游的字母串_枚举_C++_Java
java·数据结构·c++·算法·哈希算法
因特麦克斯2 小时前
每日一题&智能指针
数据结构·算法·leetcode
gaogao_jack2 小时前
[Leetcode小记] 3233. 统计不是特殊数字的数字数量
java·算法·leetcode