• 按之字形顺序打印二叉树


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


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


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

    • 訪问奇数层时,将奇数层的子节点。按先左后右的顺序将子节点压入偶数层的栈;
    • 訪问偶数层时。将偶数层的子节点,按先右后左的顺序将子节点压入奇数层的栈;
    /*
    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;
        }
    };
  • 相关阅读:
    指针与数组的区别 —— 《C语言深度剖析》读书心得
    console ouput 与 重定向输出 效率对比
    First day in 阿里
    TestNG 使用入门教程
    Spring简单使用简介
    玩转Spring JUnit+mockito+powermock单元测试(使用详解)
    Spring Boot Junit 单元测试详解
    spring @Value注入map、List、Bean、static变量方式及详细使用
    单元测试Junit使用详解
    Mockito & PowerMock详解
  • 原文地址:https://www.cnblogs.com/cynchanpin/p/7323478.html
Copyright © 2020-2023  润新知