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

相关推荐
zylyehuo1 小时前
C++基础编程
c++
月盈缺1 小时前
学习嵌入式的第二十二天——数据结构——双向链表
数据结构·学习·链表
猿究院--王升1 小时前
jvm三色标记
java·jvm·算法
一车小面包1 小时前
逻辑回归 从0到1
算法·机器学习·逻辑回归
tt5555555555552 小时前
C/C++嵌入式笔试核心考点精解
c语言·开发语言·c++
lg_cool_2 小时前
Qt 中最经典、最常用的多线程通信场景
c++·qt6.3
科大饭桶2 小时前
C++入门自学Day14-- Stack和Queue的自实现(适配器)
c语言·开发语言·数据结构·c++·容器
tt5555555555553 小时前
字符串与算法题详解:最长回文子串、IP 地址转换、字符串排序、蛇形矩阵与字符串加密
c++·算法·矩阵
元亓亓亓3 小时前
LeetCode热题100--101. 对称二叉树--简单
算法·leetcode·职场和发展
躲在云朵里`3 小时前
深入理解数据结构:从数组、链表到B树家族
数据结构·b树