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;
相关推荐
khalil102019 小时前
代码随想录算法训练营Day-53 图论01 | 110.字符串接龙、105.有向图的完全可达性、106.岛屿的周长
算法
IronMurphy19 小时前
【算法四十六】300. 最长递增子序列
算法
碧海银沙音频科技研究院19 小时前
高通QCC3084-QCC518X蓝牙耳机项目
人工智能·深度学习·算法
兩尛20 小时前
compare_exchange_weak 的用法
算法
数智工坊20 小时前
面向具身操作的视觉-语言-动作模型:让机器人真正理解并执行人类指令
论文阅读·人工智能·算法·机器人
鱼子星_20 小时前
【数据结构与算法】数据结构基础——栈和队列
c语言·数据结构
代码不停20 小时前
记忆化搜索题目练习
java·算法
闻缺陷则喜何志丹20 小时前
【C++动态规划】B3734 [信息与未来 2017] 加强版密码锁|普及+
c++·算法·动态规划·洛谷
是娇娇公主~20 小时前
力扣——105. 从前序与中序遍历序列构造二叉树详解
算法·leetcode·哈希算法
承渊政道20 小时前
【贪心算法】(经典实战应用解析(三):K次取反后最⼤化的数组和、按⾝⾼排序、优势洗牌、最⻓回⽂串、增减字符串匹配)
数据结构·c++·学习·算法·贪心算法·线性回归·哈希算法