美文网首页
2019-09-11[剑指offer-]按之字型顺序打印二叉树

2019-09-11[剑指offer-]按之字型顺序打印二叉树

作者: Coding破耳 | 来源:发表于2019-11-15 22:24 被阅读0次

题目描述

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

/*
struct TreeNode {
    int val;
    struct TreeNode *left;
    struct TreeNode *right;
    TreeNode(int x) :
            val(x), left(NULL), right(NULL) {
    }
};
*/
class Solution {
public:
    vector<vector<int> > Print(TreeNode* pRoot) {
        vector<vector<int>> tVecVec;
        if(pRoot == NULL)
        {
            return tVecVec;
        }
        
        bool bflag = false;
        queue<TreeNode*> que;
        que.push(pRoot);
        while(que.size())
        {
            int length = que.size();
            vector<int> vec;
            for(int i = 0; i < length; ++i)
            {
                TreeNode* tmp = que.front();
                vec.push_back(tmp->val);
                que.pop();
                if(tmp->left) que.push(tmp->left);
                if(tmp->right) que.push(tmp->right);
            }
            
            if(bflag)
            {
                reverse(vec.begin(),vec.end());
            }
            
            tVecVec.push_back(vec);
            
            bflag = !bflag;
            vec.clear();
        }
        
        return tVecVec;
    }
    
};

相关文章

网友评论

      本文标题:2019-09-11[剑指offer-]按之字型顺序打印二叉树

      本文链接:https://www.haomeiwen.com/subject/urewyctx.html