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;
        }
    };
  • 相关阅读:
    React开发实时聊天招聘工具 -第六章 登陆注册(2)
    React开发实时聊天招聘工具 -第六章 登陆注册(1)
    温习 socket http tcp
    高阶组件简介
    计算机组成原理(7)——输入、输出系统
    计算机组成原理(6)——总线
    计算机组成原理(5)——中央处理器
    计算机组成原理(4)——指令系统
    计算机组成原理(3)——存储层次结构
    计算机组成原理(2)——数据的表示与运算
  • 原文地址:https://www.cnblogs.com/cynchanpin/p/7323478.html
Copyright © 2011-2022 走看看