每天一道leetcode:剑指 Offer 55 - I. 二叉树的深度(适合初学者&树&图论&层次遍历)

今日份题目:

输入一棵二叉树的根节点,求该树的深度。从根节点到叶节点依次经过的节点(含根、叶节点)形成树的一条路径,最长路径的长度为树的深度。

示例

给定二叉树 [3,9,20,null,null,15,7],

复制代码
    3
   / \
  9  20
    /  \
   15   7

返回它的最大深度 3 。

提示

  1. 节点总数 <= 10000

题目思路

我们对树进行层次遍历,每到过一层就层数加一。层次遍历和广度优先遍历类似,都是使用队列,这里的队列存放同一层的所有节点,所以每次while时需要对队列中所有的节点进行操作,把他们的左右子孩子放入队列。

代码

cpp 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
 * };
 */
class Solution 
{
public:
    int maxDepth(TreeNode* root) 
    {
        if(root==NULL) return 0;
        queue<TreeNode*> p;
        p.push(root);
        int ans=0;
        while(!p.empty()) 
        {
            int n=p.size();
            for(int i=0;i<n;i++) //遍历该层的所有节点
            {
                TreeNode* cur=p.front();
                p.pop();
                if(cur->left) p.push(cur->left);
                if(cur->right) p.push(cur->right);
            }
            ans+=1; //层数加一,进入下一层
        } 
        return ans;
    }
};

提交结果

欢迎大家在评论区讨论,如有不懂的部分,欢迎在评论区留言!

更新不易,宝子们点个赞支持下,谢谢!

每天一道leetcode,大家一起在评论区打卡呀!

相关推荐
熊猫_豆豆12 分钟前
YOLOP车道检测
人工智能·python·算法
艾莉丝努力练剑27 分钟前
【Linux:文件】Ext系列文件系统(初阶)
大数据·linux·运维·服务器·c++·人工智能·算法
Once_day43 分钟前
C++之《程序员自我修养》读书总结(1)
c语言·开发语言·c++·程序员自我修养
Trouvaille ~1 小时前
【Linux】TCP Socket编程实战(一):API详解与单连接Echo Server
linux·运维·服务器·网络·c++·tcp/ip·socket
偷吃的耗子1 小时前
【CNN算法理解】:CNN平移不变性详解:数学原理与实例
人工智能·算法·cnn
坚果派·白晓明1 小时前
在鸿蒙设备上快速验证由lycium工具快速交叉编译的C/C++三方库
c语言·c++·harmonyos·鸿蒙·编程语言·openharmony·三方库
小镇敲码人1 小时前
深入剖析华为CANN框架下的Ops-CV仓库:从入门到实战指南
c++·python·华为·cann
dazzle2 小时前
机器学习算法原理与实践-入门(三):使用数学方法实现KNN
人工智能·算法·机器学习
那个村的李富贵2 小时前
智能炼金术:CANN加速的新材料AI设计系统
人工智能·算法·aigc·cann
张张努力变强2 小时前
C++ STL string 类:常用接口 + auto + 范围 for全攻略,字符串操作效率拉满
开发语言·数据结构·c++·算法·stl