欢迎大家参与本项目,贡献其他语言版本的代码,拥抱开源,让更多学习算法的小伙伴们收益!
# 二叉树的迭代遍历 > 听说还可以用非递归的方式 看完本篇大家可以使用迭代法,再重新解决如下三道leetcode上的题目: * 144.二叉树的前序遍历 * 94.二叉树的中序遍历 * 145.二叉树的后序遍历 为什么可以用迭代法(非递归的方式)来实现二叉树的前后中序遍历呢? 我们在[栈与队列:匹配问题都是栈的强项](https://mp.weixin.qq.com/s/eynAEbUbZoAWrk0ZlEugqg)中提到了,**递归的实现就是:每一次递归调用都会把函数的局部变量、参数值和返回地址等压入调用栈中**,然后递归返回的时候,从栈顶弹出上一次递归的各项参数,所以这就是递归为什么可以返回上一层位置的原因。 此时大家应该知道我们用栈也可以是实现二叉树的前后中序遍历了。 ## 前序遍历(迭代法) 我们先看一下前序遍历。 前序遍历是中左右,每次先处理的是中间节点,那么先将跟节点放入栈中,然后将右孩子加入栈,再加入左孩子。 为什么要先加入 右孩子,再加入左孩子呢? 因为这样出栈的时候才是中左右的顺序。 动画如下:  不难写出如下代码: (**注意代码中空节点不入栈**) ```C++ class Solution { public: vector