BM28 二叉树的最大深度

  • 1 递归
  • 2 层次遍历,每层遍历结束,res+1

1 递归

具体做法:

  • step 1:对于每个节点,若是不为空才能累计一次深度,若是为空,返回深度为0.
  • step 2:递归分别计算左子树与右子树的深度。
  • step 3:当前深度为两个子树深度较大值再加1。
cpp 复制代码
  int maxDepth(TreeNode* root) {
        if(root == NULL) return 0;//空节点没有深度
        
        return max(maxDepth(root->left),maxDepth(root->right))+1;//返回子树深度+1
    }

复杂度分析:

  • 时间复杂度:O(n),其中nnn为二叉树的节点数,遍历整棵二叉树;
  • 空间复杂度:O(n),最坏情况下,二叉树化为链表,递归栈深度最大为n;

2 层次遍历,每层遍历结束,res+1

cpp 复制代码
int maxDepth(TreeNode* root) {
        //空节点没有深度
        if(root == NULL)
            return 0;
        //队列维护层次后续节点
        queue<TreeNode*> q;
        //根入队
        q.push(root);
        //记录深度
        int res = 0;
        //层次遍历
        while(!q.empty()){
            //记录当前层有多少节点
            int n = q.size();
            //遍历完这一层,再进入下一层
            for(int i = 0; i < n; i++){
                TreeNode* node = q.front();
                q.pop();
                //添加下一层的左右节点
                if(node->left)
                    q.push(node->left);
                if(node->right)
                    q.push(node->right);
            }
            //深度加1
            res++;
        }
        return res;
    }

复杂度分析:

  • 时间复杂度:O(n),其中n为二叉树的节点数,遍历整棵二叉树;
  • 空间复杂度:O(n),辅助队列的空间最坏为n;
相关推荐
山甫aa2 分钟前
二叉树算法-----从零开始的算法
数据结构·算法
睡觉就不困鸭33 分钟前
第十七天 翻转字符串里的单词
数据结构·算法·哈希算法·散列表
ulias21238 分钟前
leetcode热题 - 4
算法·leetcode·职场和发展
学术阿凡提38 分钟前
Spring Boot 优雅实现异步调用:从入门到自定义线程池与异常处理
java·数据库·算法
MicroTech20251 小时前
微算法科技(NASDAQ :MLGO)量子化边缘检测技术:重塑图像处理的新范式
图像处理·科技·算法
WolfGang0073211 小时前
代码随想录算法训练营 Day47 | 图论 part05
算法·图论
猿长大人1 小时前
算法 | 轮廓提取随笔 —— 关于像素、阈值和直觉的碎碎念
图像处理·算法
啦啦啦_99991 小时前
1. 线性回归之 向量&矩阵
算法·矩阵·线性回归
DolphinDB智臾科技1 小时前
DolphinDB 走进东南大学 | 新型电力系统高频数据处理与算法落地实战
算法
Zzzzmo_1 小时前
前缀和算法
算法·前缀和