标签:思路 not else public ffffff img app 递归遍历 rgs
上一篇文章中我们讲到了二叉树的递归遍历——三分钟快速实现二叉树的递归遍历;
这不,现在就有小伙伴提出二叉树的非递归遍历的方式; 于是乎,时光也为大家聊聊如何用最简方式实现二叉树的非递归遍历;
要实现二叉树的非递归遍历,就必须要借助栈的结构特点来实现;
我们根据遍历的顺序,然后对入栈的结点进行分析遍历即可;
文中完整源码获取请关注公众号《程序员的时光》;
后台回复——数据结构源码,可以获得常见数据结构代码;
就以这个二叉树为例吧!
??
1,先序遍历;
对于任一结点P:
1,将结点P入栈,并访问结点P;
2,判断结点P的左孩子是否为空,若为空,则取栈顶结点并进行出栈操作,并将栈顶结点的右孩子置为当前的结点P,循环执行;若不为空,则将P的左孩子置为当前的结点P;
3,直到P为null并且栈为空,则遍历结束。
2,中序遍历;
对于任一结点P:
1,若其左孩子不为空,则将P入栈并将P的左孩子置为当前的P,然后对当前结点P再进行相同的处理;
2,若其左孩子为空,则取栈顶元素并进行出栈操作,访问该栈顶结点,然后将当前的P置为栈顶结点的右孩子;
3,直到P为null并且栈为空则遍历结束;
3,后序遍历;
后序遍历的非递归算法是三种顺序中最复杂的,原因在于:
1,后序遍历是先访问左、右子树,再访问根节点,而在非递归算法中,利用栈回退到时,并不知道是从左子树回退到根节点,还是从右子树回退到根节点,;
2,如果从左子树回退到根节点,此时就应该去访问右子树,而如果从右子树回退到根节点,此时就应该访问根节点,;
3,所以相比先序和中序,必须得在压栈时添加信息,以便在退栈时可以知道是从左子树返回,还是从右子树返回进而决定下一步的操作。
这里采取的做法为:
引入一个pre指针,标记访问当前节点的之前访问的节点;
如果root.right为pre,或者root.right为null,则可以判断已经从右子树访问返回。
测试函数:
测试结果:
好了,今天就先分享到这里了,下期将为大家带来常见排序算法的讲解!
更多漫画趣解编程知识的文章,欢迎关注我的微信公众号,一起学习进步!
原创实属不易,求个关注吧~
标签:思路 not else public ffffff img app 递归遍历 rgs
原文地址:https://www.cnblogs.com/huke123/p/12500247.html