每天一道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,大家一起在评论区打卡呀!

相关推荐
qing_0406039 分钟前
数据结构——二叉搜索树
数据结构·c++·二叉树·二叉搜索树
Felven23 分钟前
B. Skibidus and Ohio
算法
yonuyeung28 分钟前
代码随想录算法【Day54】
java·数据结构·算法
Ljw...33 分钟前
DeepSeek+Kimi生成高质量PPT
数据库·c++·powerpoint·ppt·deepseek
敲上瘾34 分钟前
基础dp——动态规划
java·数据结构·c++·python·算法·线性回归·动态规划
西猫雷婶1 小时前
python学智能算法(三)|模拟退火算法:深层分析
算法·机器学习·模拟退火算法
禁默1 小时前
C++之旅-C++11的深度剖析(1)
开发语言·c++
张有志_1 小时前
STL容器终极解剖:C++ vector源码级实现指南 | 从内存分配到异常安全的全流程避坑
c语言·c++·算法·开源·visual studio
挨代码1 小时前
UE_C++ —— Delegates
c++·ue
mvufi2 小时前
day58 第十一章:图论part08
数据结构·算法·图论