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

相关推荐
阳光雨滴5 分钟前
使用wpf用户控件编程落石效果动画
c++·wpf
小贾要学习1 小时前
【数据结构】C++实现红黑树
数据结构·c++
ajassi20001 小时前
开源 C++ QT QML 开发(十七)进程--LocalSocket
c++·qt·开源
StarPrayers.2 小时前
旅行商问题(TSP)(2)(heuristics.py)(TSP 的两种贪心启发式算法实现)
前端·人工智能·python·算法·pycharm·启发式算法
微露清风2 小时前
系统性学习C++-第五讲-内存管理
java·c++·学习
爱吃橘的橘猫2 小时前
嵌入式系统与嵌入式 C 语言(2)
c语言·算法·嵌入式
235162 小时前
【LeetCode】146. LRU 缓存
java·后端·算法·leetcode·链表·缓存·职场和发展
星夜钢琴手3 小时前
推荐的 Visual Studio 2026 Insider C++ 程序项目属性配置
c++·visual studio
weixin_307779133 小时前
使用Python高效读取ZIP压缩文件中的UTF-8 JSON数据到Pandas和PySpark DataFrame
开发语言·python·算法·自动化·json
柳安忆3 小时前
【论文阅读】Sparks of Science
算法