二叉树非递归遍历栈中存的是什么?
一、二叉树非递归遍历栈中存的是什么
二叉树非递归遍历栈中存的是看一眼代码就能知道, 传参传的是 node 地址, 压栈的自然也是node地址。栈的本质意义在于保存上下文环境,对于二叉树而言,递归的时候传入的值是节点。点本身才是需要储存的上下文环境,因此在非递归的时候应当把节点压入栈。以此类推,以后编写非递归代码时,递归的时候入参是什么,非递归的时候就把同样的对象压入栈即可。
部分代码:
//二叉树的存储结构
typedef struct BiTNode {
??? ElemType data;
??? struct BiTNode *lchild, *rchild;
} BiTNode, *BiTree;
//非递归中序遍历二叉树
void InOrder(BiTree) {
??? InitStack(S);
??? BiTree p = T;
??? while (p || IsEmpty(S)) {
??????? if (p) {???? //一路向左
??????????? Push(S, p);
??????????? p = p->lchild;
??????? } else {
??????????? Pop(S, p);
??????????? visit(p);
?????????? ?p = p->rchild;
??????? }
??? }
}
延伸阅读:
二、几个特殊的二叉树
(1)斜树
所有的结点都只有左子树的二叉树叫左斜树。所有结点都是只有右子树的二叉树叫右斜树。这两者统称为斜树。
(2)满二叉树棵高度为h,且含有2 h ? 1 2^h-12h?1个结点的二叉树称为满二叉树,即树中的每层都含有非常多的结点。满二叉树的叶子结点都集中在二叉树的最下一层,并且除叶子结点之外的每个结点度数均为2 22。可以对满二叉树按层序编号:约定编号从根结点(根结点编号为1 11)起,自上而下,自左向右。这样,每个结点对应一个编号,对于编号为i的结点,若有双亲,则其双亲为i / 2 i/2i/2,若有左孩子,则左孩子为2 i 2i2i;若有右孩子,则右孩子为2 i + 1 2i+12i+1。

相关推荐HOT
更多>>
FTP上传和WEB上传有什么区别?
一、FTP上传和WEB上传的区别1、上传方式不同FTP上传是通过FTP客户端上传文件到FTP服务器,FTP客户端需要连接到FTP服务器,然后通过FTP协议实现...详情>>
2023-10-17 13:38:13
php用什么编辑器编程比较好?
一、php比较好的编辑器1.SublimeText3工具简介:Sublime Text是一款目前非常流行的代码编辑器优点是:体积适中,40M左右,运行流畅,有丰富的插...详情>>
2023-10-17 12:50:13
Linux系统函数read()/write()/pread()/pwrite()有什么区别?
一、Linux系统函数read()/write()/pread()/pwrite()的区别read() 和 write():这两个函数分别用于从文件中读取数据和向文件写入数据。它们基于...详情>>
2023-10-17 10:27:08
什么是vpn?
一、vpn概念VPN即虚拟专用网,指通过VPN技术在公有网络中构建专用的虚拟网络。vpn被定义为通过一个公用网络(通常是因特网)建立一个临时的、安全...详情>>
2023-10-17 09:09:19热门推荐
FTP上传和WEB上传有什么区别?
沸Android按下开机键到启动发生什么?
热怎么管控项目进度?
热php用什么编辑器编程比较好?
新Python的a//b和int(a/b)的区别?
JDK、JRE、JVM有什么区别?
JS正则中exec与match有哪些区别?
ASM与JAVASSIST有什么区别?
python能用来做什么?
什么软件可以打开zip格式文件?
无锁队列解决了什么问题?
中序遍历的中序是什么意思?
Linux系统函数read()/write()/pread()/pwrite()有什么区别?
Swift加括号的计算变量是什么?
技术干货






