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

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

题目:

请实现一个函数按照之字形顺序打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右到左的顺序打印,第三行再按照从左到右的顺序打印,其他行以此类推。


例如:

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


   3

  / \

 9  20

   /  \

  15   7

返回其层次遍历结果:


[

 [3],

 [20,9],

 [15,7]

]


提示:


节点总数 <= 1000


4b0cf2bbc096102327b13a1568710e66_c32f2ae6ff664bb7adb3601537f98033.png


接上篇思路,在每偶数层遍历结束,将数组反转存入即可

 

class Solution {
public:
    vector<vector<int>> levelOrder(TreeNode* root) 
    {
        vector<vector<int>>sum;//定义一个二维答案数组
        queue<TreeNode*>q;//定义一个队列
        if(root!=NULL)
        q.push(root);//根节点不为空时存入
        int k=0;
        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);
            }
            if(k%2)
            reverse(tmp.begin(),tmp.end());//偶数层反转存入
            sum.push_back(tmp);
            k++;
        }
        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】