力扣HOT100(33)二叉树的最大深度

方法一:深度优先搜索(递归法,面试首选)

1. 核心思路(分治思想)

二叉树的深度有一个铁律

当前节点的深度 = max (左子树深度,右子树深度) + 1

  • 先算左子树的最大深度
  • 再算右子树的最大深度
  • 取两者的最大值,加上当前节点本身(+1),就是当前节点的深度
  • 递归终止条件:空节点的深度为 0(没有节点,深度就是 0)

这个思路本质是后序遍历:先处理左子树,再处理右子树,最后处理当前节点。

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) {
        //递归

        //为空 就返回
        if(root == nullptr) return 0;

        //否则就一直左子树 右字数遍历
        return max(maxDepth(root->left),maxDepth(root->right))+1;
        
    }
};

方法二:广度优先搜索(层序遍历法,面试进阶)

1. 核心思路

层序遍历就是一层一层地遍历树,每遍历完一层,深度就加 1。

  • 用队列存储当前层的所有节点
  • 每次先记录当前队列的大小(也就是当前层的节点数)
  • 一次性把当前层的所有节点都处理完,把它们的左右孩子入队
  • 处理完一层,深度加 1
  • 直到队列为空,返回深度
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) {
       //层序 BFS 广度优先搜索

       //仍然是如果根为空 直接返回
       if(root == nullptr) return 0;
       queue<TreeNode *> Q;//创建一个队列
       Q.push(root);//把当前的根入队
       int ans = 0;
       while(!Q.empty()){
        //循环条件:Q队列不为空
        int sz = Q.size();
        while(sz>0){
            TreeNode* node = Q.front();//最先入队的存到node中
            Q.pop();// 弹出队首
            if(node->left){
                Q.push(node->left);
            }
            if(node->right){
                Q.push(node->right);
            }
            sz -=1
        }
        ans += 1;
       }
       return ans;

    }
};
相关推荐
Deepoch1 小时前
Deepoc数学大模型:重塑半导体研发与制造的核心算法范式
人工智能·算法·机器学习·半导体·deepoc·数学大模型
一支黑色の铅笔1 小时前
MongoDB Aggregation Pipeline 常用 Stage 速查
数据库·算法·mongodb
Bingorl1 小时前
机器学习之决策树算法
算法·决策树·机器学习
qingyulee2 小时前
线性回归、决策树
人工智能·算法·线性回归
Zhang~Ling2 小时前
C++ 继承机制详解下:多继承、虚继承与菱形继承底层原理
开发语言·c++·算法
西安邮电大学2 小时前
2026华为OD机考真题附答案-计算数列位置N的值
java·算法
AI算法沐枫2 小时前
机器学习经典小项目4:泰坦尼克号生存预测
人工智能·python·深度学习·线性代数·算法·机器学习·回归
洛水水2 小时前
【力扣100题】60.缺失的第一个正数
leetcode·哈希算法
玖釉-2 小时前
单词搜索:二维网格中的 DFS 回溯与剪枝优化
c++·windows·算法·深度优先·剪枝