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


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


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


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

    • 訪问奇数层时,将奇数层的子节点。按先左后右的顺序将子节点压入偶数层的栈;
    • 訪问偶数层时。将偶数层的子节点,按先右后左的顺序将子节点压入奇数层的栈;
    /*
    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;
        }
    };
  • 相关阅读:
    JDK JRE Java虚拟机的关系
    apache和tomcat区别
    JBoss Web和 Tomcat的区别
    SOAP 与 restful service区别
    IntelliJ Idea 常用快捷键列表
    Win7用户文件夹转移
    相同IP和Mac地址的问题
    WebDriver 浅析
    Web UI 自动化测试
    python中xlrd模块的使用
  • 原文地址:https://www.cnblogs.com/cynchanpin/p/7323478.html
Copyright © 2020-2023  润新知