代码随想录算法训练营第十三天 | 144.二叉树的前序遍历 145.二叉树的后序遍历 94.二叉树的中序遍历

文章介绍了如何使用非递归方法进行二叉树的前序、后序和中序遍历。对于前序遍历,利用栈模拟递归,先访问根节点,再依次处理左右子树。后序遍历则先将左右子树压栈,最后访问根节点,然后反转结果。中序遍历则需要额外的指针来跟踪当前处理的节点。
摘要由CSDN通过智能技术生成

144.二叉树的前序遍历

初见想法:递归法非常简单,这里主要是想用非递归法来解决

class Solution {
public:
    vector<int> preorderTraversal(TreeNode* root) {
        vector<int> ans;
        stack<TreeNode*> st;
        
        if (root == nullptr) return ans;        
        st.push(root);

        while (!st.empty())
        {
            TreeNode* node = st.top();
            st.pop();

            ans.push_back(node->val);
            else continue;

            if (node->right != nullptr) st.push(node->right);
            if (node->left != nullptr) st.push(node->left);
        }

        return ans;
    }
};
  1. 在非递归法中,使用stack模拟递归的过程,stack后进先出,而前序遍历的顺序为中左右,先遍历左边的,所以在stack的入栈过程中,应该先让右边的入栈。

145.二叉树的后序遍历

class Solution {
public:
    vector<int> postorderTraversal(TreeNode* root) {
        vector<int> ans;
        stack<TreeNode*> st;

        if (root == nullptr) return ans;
        st.push(root);

        while (!st.empty())
        {
            TreeNode* node = st.top();
            st.pop();

            ans.push_back(node->val);
            
            if (node->left != nullptr) st.push(node->left);
            if (node->right != nullptr) st.push(node->right);
        }

        reverse(ans.begin(), ans.end());

        return ans;
    }
};
  1. 二叉树的后序遍历和前序遍历非常相似,后序遍历的顺序为左右中,所以在代码中可以先中右左,然后reverse整个vector, 这样ans的顺序就是左右中。

94.二叉树的中序遍历

class Solution {
public:
    vector<int> ans;
    vector<int> inorderTraversal(TreeNode* root) {
        vector<int> ans;
        stack<TreeNode*> st;
        
        TreeNode* curr = root;

        while (!st.empty() || curr != nullptr)
        {
            if (curr != nullptr)
            {
                st.push(curr);
                curr = curr->left;
            }
            else
            {
                TreeNode* node = st.top();
                st.pop();
                
                ans.push_back(node->val);
                curr = node->right;
            }
        }

        return ans;
    }
};

二叉树的中序遍历,与前序后序不同的是,中序遍历多了一个指针指向了当前需要处理的节点,stack用来存储遍历过的节点

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值