102. 二叉树的层序遍历

原题链接:102. 二叉树的层序遍历

以下代码为模板,需要层序遍历时都可以使用该模板进行代码更改

全代码:

cpp 复制代码
class Solution {
public:
    vector<vector<int>> levelOrder(TreeNode* root) {
        //创建一个TreeNode* 队列用于存储树中的每层结点元素
        queue<TreeNode*> que;
        //如果树不为空,则将树以及树的全部结点push进que中
        if(root != NULL) que.push(root);
        //创建二维容器用于存放层序遍历的值
        vector<vector<int>> result;
        while(!que.empty())
        {
            //记录下当前层中有多少个结点元素
            int size = que.size();
            //创建容器用于存放当前层所有结点的值
            vector<int> vec;
            for(int i = 0; i < size;i++)
            {//用于遍历队列内存储的结点元素

                //存储队列头元素
                TreeNode* node = que.front();
                //将头元素弹出
                que.pop();
                //将头元素的值push到vec内
                vec.push_back(node ->val);
                //将子树的左右结点push进队列内,以下次备用
                if(node ->left) que.push(node ->left);
                if(node ->right) que.push(node ->right);
            }
            result.push_back(vec);
        }
        return result;
    }
};
相关推荐
lightqjx7 小时前
【算法】数据结构_单调栈
数据结构·算法·单调栈
计算机安禾7 小时前
【算法分析与设计】第44篇:随机化复杂度类:RP、BPP与去随机化猜想
java·数据结构·数据库·算法·机器学习
枕星而眠8 小时前
【数据结构】树与二叉树基础知识点总结
数据结构·c++·后端·算法·运维开发
fei_sun8 小时前
【SystemVerilog验证】数据类型(待补充)
数据结构·systemverilog
无忧.芙桃9 小时前
数据结构之单链表
c语言·开发语言·数据结构
HZ·湘怡9 小时前
二叉树 1
数据结构·算法·二叉树·
雨落在了我的手上9 小时前
Java数据结构(二):时间和空间复杂度
数据结构
悠仁さん9 小时前
list 链式表基本功能模拟实现(双向有头指针循环链表)
c语言·数据结构·链表·list
xxwxx__9 小时前
栈(Stack)详解:概念、实现与避坑指南
c语言·数据结构
少司府9 小时前
C++进阶:map和set的使用
开发语言·数据结构·c++·容器·stl·set·map