c语言? 求一个二叉树的后序遍历非递归算法?
浏览量:1156
时间:2021-03-14 05:53:07
作者:admin
求一个二叉树的后序遍历非递归算法?
此主题为p=t while(1){if(p->rchild)//如果有右子级,则右子级必须在序列中的当前节点之后(如果有另一个左子级,则右子级也在整个左子树之后)p=p->rchild else if(p->lchild)//如果没有右子级,但有左子级,左子必须在当前节点之后的序列P=P->lchild在我看来,递归遍历是很容易理解的,除非你不懂C语言的递归,这也是很难理解的。有两个步骤:1。了解前、中、后遍历过程。查看算法并回味遍历过程。
如何理解二叉树的前、中、后序的递归和非递归遍历?
通常情况下,有必要花更多的时间。首先需要了解堆栈的操作和意义,还需要了解遍历二叉树的思想。有人用节点着色来编写非递归算法,即黑、灰、白三种颜色代表节点的状态,未被访问的节点为白色,未被访问的节点为灰色,被访问的节点为黑色。对于中间顺序遍历,除非访问了左子树,否则需要访问当前节点,所以依次沿左子树搜索,找到叶子后访问,然后退出右堆栈上的元素,并在右子树上执行相应的操作,直到堆栈为空。
版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。
下一篇
九本布局 九运房屋布局