力扣 剑指 Offer 32 - II. 从上到下打印二叉树 II

简介: 力扣 剑指 Offer 32 - II. 从上到下打印二叉树 II

题目:


从上到下按层打印二叉树,同一层的节点按从左到右的顺序打印,每一层打印到一行。


例如:

给定二叉树: [3,9,20,null,null,15,7],


   3

  / \

 9  20

   /  \

  15   7

返回其层次遍历结果:


[

 [3],

 [9,20],

 [15,7]

]


提示:


节点总数n <= 1000


1c18c60d4d10d8253b7074c09a3f9e47_9eba9e5365a24d978438432734c88f6e.png


按层打印: 题目要求的二叉树的 从上至下 打印(即按层打印),又称为二叉树的 广度优先搜索(BFS)。BFS 通常借助 队列 的先入先出特性来实现。


II. 每层打印到一行: 将本层全部节点打印到一行,并将下一层全部节点加入队列,以此类推,即可分为多行打印。

class Solution {
public:
    vector<vector<int>> levelOrder(TreeNode* root) 
    {
        vector<vector<int>>sum;//定义二维答案数组
        queue<TreeNode*>q;//定义一个队列
        if(root!=NULL)
        q.push(root);
        while(!q.empty())
        {
            vector<int> tmp;
            for(int i=q.size();i>0;i--)//每次遍历一层
            {
            root=q.front();
            q.pop();//查询过的直接清除出队列
            tmp.push_back(root->val);//将节点元素存入数组
            if(root->left!=NULL)//搜寻左子树
            q.push(root->left);
            if(root->right!=NULL)//搜寻右子树
            q.push(root->right);
            }
            sum.push_back(tmp);//每次遍历过后将一层结果存进二维答案数组
        }
        return sum;//返回答案
    }
};

目录
相关文章
|
18天前
|
存储 SQL 算法
LeetCode力扣第114题:多种算法实现 将二叉树展开为链表
LeetCode力扣第114题:多种算法实现 将二叉树展开为链表
|
13天前
|
算法
二刷力扣--二叉树(3)
二刷力扣--二叉树(3)
|
13天前
二刷力扣--二叉树(2)
二刷力扣--二叉树(2)
|
13天前
二刷力扣--二叉树(1)基础、遍历
二刷力扣--二叉树(1)基础、遍历
|
18天前
|
存储 算法 数据可视化
力扣156题最全解法:如何上下翻转二叉树(递归与迭代方法详解,附图解)
力扣156题最全解法:如何上下翻转二叉树(递归与迭代方法详解,附图解)
|
18天前
|
存储 机器学习/深度学习 算法
LeetCode 题目 102:二叉树的层序遍历
LeetCode 题目 102:二叉树的层序遍历
|
18天前
|
存储 数据采集 算法
力扣题目101:对称二叉树
力扣题目101:对称二叉树
|
18天前
|
算法 数据可视化 数据挖掘
LeetCode题目104: 二叉树的最大深度(递归\迭代\层序遍历\尾递归优化\分治法实现 )
LeetCode题目104: 二叉树的最大深度(递归\迭代\层序遍历\尾递归优化\分治法实现 )
LeetCode题目104: 二叉树的最大深度(递归\迭代\层序遍历\尾递归优化\分治法实现 )
|
18天前
|
存储 缓存 算法
LeetCode力扣题目111:多种算法对比实现二叉树的最小深度
LeetCode力扣题目111:多种算法对比实现二叉树的最小深度
|
18天前
|
SQL 算法 数据可视化
LeetCode题目99:图解中叙遍历、Morris遍历实现恢复二叉树搜索树【python】
LeetCode题目99:图解中叙遍历、Morris遍历实现恢复二叉树搜索树【python】