二叉树非递归遍历代码 急!链表形式的二叉树,使用非递归算法如何交换左右子树?
浏览量:1649
时间:2021-03-13 22:56:32
作者:admin
急!链表形式的二叉树,使用非递归算法如何交换左右子树?
如果需要对所有节点的左右子树进行变换,主要有两种方式。深度优先遍历,从根到最小子树的访问解决问题。当所有节点都被访问时,交换就完成了。或者BFS广度优先从根节点依次交换左右子树,访问完所有节点后交换完成。建议使用BFS。逻辑简单易懂,实现简单。排队感觉也比堆积如山好。
花一晚上也无法理解二叉树的非递归遍历,我该继续学下去吗?
通常情况下,有必要花更多的时间。首先需要了解堆栈的操作和意义,还需要了解遍历二叉树的思想。有人用节点着色来编写非递归算法,即黑、灰、白三种颜色代表节点的状态,未被访问的节点为白色,未被访问的节点为灰色,被访问的节点为黑色。对于中间顺序遍历,除非访问了左子树,否则需要访问当前节点,所以依次沿左子树搜索,找到叶子后访问,然后退出右堆栈上的元素,并在右子树上执行相应的操作,直到堆栈为空。
二叉树非递归遍历代码 非递归中序遍历二叉树 层序遍历二叉树非递归
版权声明:本文内容由互联网用户自发贡献,本站不承担相关法律责任.如有侵权/违法内容,本站将立刻删除。