一棵二叉树的结点若无子树,则可将其子树看作 “.”,输入时,按照前序序列的顺序输入该结点的内容。对 下图,其输入序列为 ABD..EH...CF.I..G..。 [输出] 若为空二叉树,则输出:THIS IS A EMPTY BINARY TREE。若二叉树不空,按后序序列输出,对上例,输出结果为:DHEBIFGCA。
时间: 2024-02-11 16:07:57 浏览: 69
森林的前序、中序遍历-数据结构-树
输入序列为 ABD..EH...CF.I..G..
我们可以用一个栈来实现二叉树的后序遍历,具体方法如下:
1. 从前往后遍历输入序列,将每个结点压入栈中。同时,记录栈中当前结点的父节点(初始值为NULL)。
2. 如果遇到一个空结点,说明该结点没有左子树或右子树,此时需要将父节点指向栈顶结点(即当前结点的父节点),并弹出栈顶结点。
3. 如果遇到一个非空结点,将其作为栈顶结点的左子树(如果栈顶结点没有左子树)或右子树(如果栈顶结点已经有左子树),并更新父节点为当前结点。
4. 当所有结点都入栈后,从栈顶开始依次弹出结点,即可得到二叉树的后序遍历。
根据上述方法,对于输入序列 ABD..EH...CF.I..G..,可以得到如下二叉树:
```
A
/ \
B C
\ / \
D E F
\ \
H I
\
G
```
然后,按照上述方法,我们可以得到二叉树的后序遍历为 DHEBIFGCA。
因此,输出结果为 DHEBIFGCA。
阅读全文