(迭代法)145. 二叉树的后序遍历

原题链接:(迭代法)145. 二叉树的后序遍历

思路是跟迭代法前序遍历一样的

但是要注意,需要交换入栈顺序

遵循入栈先进后出原则,迭代法的前序顺序是中右左,而后序是中左右,这一点是跟递归的前序后序顺序相反的

最后要把result容器内的值反转一下 就是迭代法后续遍历的值

全代码:

cpp 复制代码
class Solution {
public:
    vector<int> postorderTraversal(TreeNode* root) {
        stack<TreeNode*> stackA;
        vector<int> result;
        stackA.push(root);
        while(!stackA.empty())
        {
            TreeNode* Node = stackA.top();
            stackA.pop();
            if(Node == NULL) continue;
            result.push_back(Node ->val);
            //相比于前序,后续需要更改下入栈顺序,先进后出
            //所以迭代法前序入栈应该是中右左,后序应该是中左右,这一点是跟递归相反的
            stackA.push(Node ->left);
            stackA.push(Node ->right);
        }
        reverse(result.begin(),result.end());
        return result;
    }
};
相关推荐
菜鸟233号6 小时前
力扣669 修剪二叉搜索树 java实现
java·数据结构·算法·leetcode
jingfeng5148 小时前
哈希表的概念+实现
数据结构·哈希算法·散列表
ホロHoro9 小时前
数据结构非线性部分(1)
java·数据结构·算法
沉下去,苦磨练!9 小时前
实现二维数组反转
java·数据结构·算法
玖剹9 小时前
哈希表相关题目
数据结构·c++·算法·leetcode·哈希算法·散列表
红豆诗人9 小时前
数据结构初阶知识--单链表
c语言·数据结构
L_090710 小时前
【C++】高阶数据结构 -- 二叉搜索树(BST)
数据结构·c++
仰泳的熊猫10 小时前
1150 Travelling Salesman Problem
数据结构·c++·算法·pat考试
lixzest11 小时前
C++中经常用的头文件介绍
数据结构·c++·算法
一起养小猫12 小时前
《Java数据结构与算法》第四篇(四):二叉树的高级操作查找与删除实现详解
java·开发语言·数据结构·算法