!力扣102. 二叉树的层序遍历

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

示例 1:

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

cpp 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:


    vector<vector<int>> levelOrder(TreeNode* root) {
        vector<vector<int>> ret;
        if(!root){return ret;}
        
        queue<TreeNode*> q;//存放节点的队列
        q.push(root);//在末尾加入一个元素
        while(!q.empty()){
            int n=q.size();//每一层的元素个数
            vector<int> cur;//记录每一层节点值的数组
            for(int i=0;i<n;i++){
                TreeNode* tmp=q.front();//返回第一个元素
                q.pop();//弹出第一个元素
                cur.push_back(tmp->val);
                if(tmp->left){q.push(tmp->left);}
                if(tmp->right){q.push(tmp->right);}
            }
            ret.push_back(cur);
        }
        return ret;
    }
};
相关推荐
L_cl29 分钟前
【Python 算法零基础 3.递推】
算法
int型码农42 分钟前
数据结构第七章(四)-B树和B+树
数据结构·b树·算法·b+树
先做个垃圾出来………1 小时前
汉明距离(Hamming Distance)
开发语言·python·算法
小羊在奋斗2 小时前
【LeetCode 热题 100】二叉树的最大深度 / 翻转二叉树 / 二叉树的直径 / 验证二叉搜索树
算法·leetcode·职场和发展
2301_794461573 小时前
力扣-283-移动零
算法·leetcode·职场和发展
编程绿豆侠3 小时前
力扣HOT100之二叉树:98. 验证二叉搜索树
算法·leetcode·职场和发展
技术流浪者3 小时前
C/C++实践(十)C语言冒泡排序深度解析:发展历史、技术方法与应用场景
c语言·数据结构·c++·算法·排序算法
I AM_SUN4 小时前
98. 验证二叉搜索树
数据结构·c++·算法·leetcode
学习中的码虫4 小时前
数据结构基础排序算法
数据结构·算法·排序算法
_安晓4 小时前
数据结构 -- 顺序查找和折半查找
数据结构