【LeetCode热题100】102. 二叉树的层序遍历(二叉树)

一.题目要求

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

二.题目难度

中等

三.输入样例

示例 1:

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

输出:[[3],[9,20],[15,7]]

示例 2:

输入:root = [1]

输出:[[1]]

示例 3:

输入:root = []

输出:[]

提示:

树中节点数目在范围 [0, 2000] 内

-1000 <= Node.val <= 1000

四.解题思路

基本功

五.代码实现

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>> ans;
        queue<TreeNode*> tmp;
        TreeNode* p = root;
        if(root == nullptr) return {};
        tmp.push(root);
        while(!tmp.empty())
        {
            int size = tmp.size();
            vector<int> valtmp;
            for(int i = 0; i < size; i++)
            {
                valtmp.push_back(p->val);
                tmp.pop();
                if(p->left) tmp.push(p->left);
                if(p->right) tmp.push(p->right);
                p = tmp.front();
            }
            ans.push_back(valtmp);
        }
        return ans;
    }
};

六.题目总结

相关推荐
南石.2 分钟前
JVM 基础、GC 算法与 JProfiler 监控工具详解
jvm·算法
DdddJMs__13512 分钟前
C语言 | Leetcode C语言题解之第458题可怜的小猪
c语言·leetcode·题解
哎呀呀嗯呀呀18 分钟前
class 031 位运算的骚操作
java·算法·位运算
时清云34 分钟前
【算法】合并两个有序链表
前端·算法·面试
轩辰~1 小时前
磁盘存储链式结构——B树与B+树
数据结构·b树·算法
2401_857297911 小时前
秋招内推2025-招联金融
java·前端·算法·金融·求职招聘
通信仿真实验室2 小时前
MATLAB使用眼图分析QPSK通信系统接收端匹配滤波后的信号
开发语言·算法·matlab
通信仿真实验室2 小时前
(15)衰落信道模型作用于信号是相乘还是卷积
开发语言·人工智能·算法·matlab
Run with the Wind2 小时前
【2024.9.29练习】R 格式
算法
Jeremy_121382 小时前
三种波束形成方法的区别(MVDR、MMSE以及MSNR波束形成器)
算法