zoukankan      html  css  js  c++  java
  • 按之字形顺序打印二叉树

    题目描写叙述:按之字形顺序打印二叉树
    请实现一个函数依照之字形打印二叉树,即第一行依照从左到右的顺序打印,第二层依照从右至左的顺序打印。第三行依照从左到右的顺序打印,其它行以此类推。


    解析:
    要分层打印,不能用常规方法。訪问一个节点后,将该节点的左右子节点压入队列。


    奇数层从左到右打印。偶数层从右向左打印。使用两个栈存储每一层的节点。

    • 訪问奇数层时,将奇数层的子节点。按先左后右的顺序将子节点压入偶数层的栈;
    • 訪问偶数层时。将偶数层的子节点,按先右后左的顺序将子节点压入奇数层的栈;
    /*
    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> > result;
            if (pRoot == NULL)
                return result;
            stack<TreeNode*> stk1, stk2;
            stk1.push(pRoot); // stk1 存储奇数层;stk2 存储偶数层
            while (!stk1.empty() || !stk2.empty()) {
                vector<int> level_vec;
                if (!stk1.empty()) {
                    while (!stk1.empty()) {
                        TreeNode* pTop = stk1.top();
                        level_vec.push_back(pTop->val);
                        if (pTop->left != NULL) // 入栈先左后右。出栈时从右向左(偶数层)
                            stk2.push(pTop->left);
                        if (pTop->right != NULL)
                            stk2.push(pTop->right);
                        stk1.pop();
                    }
                } else {
                    while (!stk2.empty()) {
                        TreeNode* pTop = stk2.top();
                        level_vec.push_back(pTop->val);
                        if (pTop->right != NULL) // 入栈先右后左。出栈时先左后右(奇数层)
                            stk1.push(pTop->right);
                        if (pTop->left != NULL)
                            stk1.push(pTop->left);
                        stk2.pop();                   
                    }
                }
                result.push_back(level_vec);
            }
            return result;
        }
    };
  • 相关阅读:
    数据的输入输出
    运算符和表达式
    深入理解Magento – 第三章 – 布局,块和模板
    压抑中......
    css控制图片自适应大小
    问来北京的追求是什么
    magento目录结构精编版
    无所事事的日子。
    jQuery实现等比例缩放大图片让大图片自适应页面布局
    MVC 小常识
  • 原文地址:https://www.cnblogs.com/cynchanpin/p/7323478.html
Copyright © 2011-2022 走看看