您的位置:首页 > Web前端

剑指offer:按之字形顺序打印二叉树

2016-04-11 20:13 393 查看


题目描述

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

/*我的解法是用两个栈来打印,第一个栈st1打印奇数层,第二个栈st2打印偶数层。

        先将根节点压入st1,然后将st1中元素出栈并访问元素,出栈的同时,将每个节点的右孩子、左孩子压入栈st2。直至栈st1空。

        这个时候再处理下一层,即栈st2,同样是出栈并访问元素,出栈的同时,将每个节点的左孩子、右孩子压入st1。直至栈st2为空。

        重复上面的过程,直至整棵树遍历结束。

*/

/*树节点的说明

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> > tree;

        if (NULL == pRoot){

            return tree;

        }

        stack<TreeNode*> st1;

        stack<TreeNode*> st2;

        TreeNode *pNode;

        vector<int> valvec;

        st1.push(pRoot);

        

        while(!st1.empty()){

            valvec.clear();

            while(!st1.empty()){

                pNode = st1.top();

                valvec.push_back(pNode->val);

                if (pNode->left){

                    st2.push(pNode->left);

                }

                if (pNode->right){

                    st2.push(pNode->right);

                }

                st1.pop();

            }

            tree.push_back(valvec);

            valvec.clear();

            while (!st2.empty()){

                pNode = st2.top();

                valvec.push_back(pNode->val);

                if (pNode->right){

                    st1.push(pNode->right);

                }

                if (pNode->left){

                    st1.push(pNode->left);

                }

                st2.pop();

            }

            if (!valvec.empty()){

                tree.push_back(valvec);

            }   

        }

        return tree;

    }

    

};
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: