【练习】【二叉树】力扣热题100 102. 二叉树的层序遍历

题目

  1. 二叉树的层序遍历
    给你二叉树的根节点 root ,返回其节点值的 层序遍历 。 (即逐层地,从左到右访问所有节点)。
    示例 1:

输入:root = [3,9,20,null,null,15,7]

输出:[[3],[9,20],[15,7]]
示例 2:

输入:root = [1]

输出:[[1]]
示例 3:

输入:root = []

输出:[]

来源:力扣热题100 102. 二叉树的层序遍历


思路(注意事项)

  • 队列定义为指针类型

核心

  • 定义队列
  • 根节点入队
  • 队列非空时循环
    • 遍历队列中的所有元素并加入临时结果集
    • 将临时结果集加入最终结果集

纯代码

c 复制代码
class Solution {
private:
    vector<vector<int>> ans;  
public:
    vector<vector<int>> levelOrder(TreeNode* root) {
        if (!root) return {};
        queue<TreeNode*> q;
        q.push(root);
        
        while (!q.empty())
        {
            int n = q.size();
            vector<int> path;
            while (n --)
            {
                auto tmp = q.front();
                q.pop();
                path.push_back(tmp -> val);

                if (tmp -> left) q.push(tmp -> left);
                if (tmp -> right) q.push(tmp -> right);
            }
            ans.push_back(path);
        }
        return ans;
    }
};

题解(加注释)

c 复制代码
class Solution {
private:
    vector<vector<int>> ans; // 用于存储层序遍历的结果

public:
    vector<vector<int>> levelOrder(TreeNode* root) {
        // 如果根节点为空,直接返回空结果
        if (!root) return {};

        // 使用队列辅助层序遍历
        queue<TreeNode*> q;
        q.push(root); // 将根节点入队

        // 开始层序遍历
        while (!q.empty()) {
            int n = q.size(); // 当前层的节点数
            vector<int> path; // 用于存储当前层的节点值

            // 遍历当前层的所有节点
            while (n--) {
                TreeNode* tmp = q.front(); // 取出队头节点
                q.pop(); // 将队头节点出队

                path.push_back(tmp->val); // 将当前节点的值加入当前层的路径

                // 如果当前节点有左子节点,将左子节点入队
                if (tmp->left) q.push(tmp->left);
                // 如果当前节点有右子节点,将右子节点入队
                if (tmp->right) q.push(tmp->right);
            }

            // 将当前层的路径加入结果集
            ans.push_back(path);
        }

        // 返回层序遍历的结果
        return ans;
    }
};
相关推荐
爱睡懒觉的焦糖玛奇朵2 小时前
【从视频到数据集:焦糖玛奇朵的魔法工具使用说明】
人工智能·python·深度学习·学习·算法·yolo·音视频
Runawayliquor2 小时前
opbase:CANN 所有算子的公共地基
大数据·数据库·人工智能·算法
徐安安ye2 小时前
FlashAttention 为什么对序列长度这么“敏感”?
人工智能·算法
kyle~3 小时前
机器视觉---熔池相机(穿透强光的视觉感知)
c++·数码相机·计算机视觉·机器人·焊接机器人
宏笋3 小时前
C++ Coroutines(协程) 详解
c++
王老师青少年编程4 小时前
csp信奥赛C++高频考点专项训练之前缀和&差分 --【一维前缀和】:求区间和
c++·前缀和·csp·高频考点·信奥赛·求和区间和
黎阳之光4 小时前
黎阳之光:以视频孪生重构智能监盘,为燃机打造新一代智慧电厂大脑
大数据·人工智能·算法·安全·数字孪生
绝知此事4 小时前
【算法突围 02】树形结构与数据库索引:树形结构与数据库索引:从 BST 到 B+ 树的演化与 MySQL 优化
数据库·mysql·算法·面试·b+树
kyle~4 小时前
机器人时间链路---工程流程示例
c++·3d·机器人·ros2
清木!5 小时前
排序算法比较
数据结构·算法·排序算法