力扣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;

    }
};
相关推荐
apcipot_rain9 小时前
计科八股20260616(2)/面经——线性代数对称阵求n次幂、概率论最大似然估计
算法
cici158749 小时前
彩色图像模糊增强(Fuzzy Enhancement)MATLAB 实现
开发语言·算法·matlab
宝贝儿好9 小时前
【LLM】第二章:HuggingFace入门学习
人工智能·深度学习·神经网络·学习·算法·自然语言处理
凌波粒10 小时前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
啵啵啵鱼10 小时前
数组---完
算法·排序算法
嘿黑嘿呦10 小时前
chap 8排序
算法·蓝桥杯·排序算法·软件工程
richdata10 小时前
需求预测终极指南:零售商品预测方法、算法与AI实践
人工智能·算法·零售
隔窗听雨眠10 小时前
C语言函数递归从入门到精通(下):性能优化与工程实践
c语言·算法·性能优化
退休倒计时11 小时前
【每日一题】LeetCode 146. LRU 缓存 TypeScript
算法·leetcode·缓存·typescript
珊瑚里的鱼11 小时前
【递归】汉诺塔
算法·深度优先