原理:
二叉树的后序序列遍历过程是:左→右→根。中序序列遍历过程是:左→根→右。
已知后序序列可以唯一确定根结点,即:后序序列的最后一个结点就是根结点。确定完根结点之后,根据中序序列可以确定根结点的左子树和右子树,即:在中序序列中根结点的左边是左子树,根结点的右边是右子树。
例题:
已知某二叉树的后序序列为GDBEFCA,中序序列为DGBAECF,则构造该二叉树的过程如下图。
详细过程如下:
step1:后序序列为GDBEFCA,中序序列为DGBAECF
可以得到:A是该二叉树根结点,DGB是A结点的左子树,ECF是A结点的右子树。
如图:
step2:先看左子树:DGB,分析它。
从二叉树的后序序列 GDBEFCA 中找到DGB按照二叉树的后序序列中的顺序写出来,即:GDB
它就是左子树DGB的后序序列。再从二叉树的中序序列 DGBAECF 中找到DGB按照二叉树的中
序序列中的顺序写出来,即:DGB它就是左子树DGB的中序序列。
于是有,左子树DGB的后序序列为:GDB,中序序列为:DGB
可以得到:B是根结点,DG是B结点的左子树
如图:
step3:再看左子树:DG,分析它。
从二叉树的后序序列 GDBEFCA 中找到DG按照二叉树的后序序列中的顺序写出来,即:GD它就
是左子树DG的后序序列。再从二叉树的中序序列 DGBAECF 中找到DG按照二叉树的中序序列中
的顺序写出来,即:DG它就是左子树DG的中序序列。
于是有,左子树DG的后序序列为:GD,中序序列为:DG
可以得到:D是根结点,G是B结点的右子树。
如图:
至此A结点的左子树分析完毕,接下来是右子树。
step1:从二叉树的后序序列 GDBEFCA 中找到ECF按照二叉树的后序序列中的顺序写出来,即:EFC它
就是右子树ECF的后序序列。再从二叉树的中序序列 DGBAECF 中找到ECF按照二叉树的中序序
列中的顺序写出来,即:ECF它就是右子树ECF的中序序列。
于是有,右子树ECF的后序序列为:EFC,中序序列为:ECF
可以得到:C是根结点,E是C结点的左子树,F是C结点的右子树
如图:
以上就是根据二叉树的先序序列和中序序列成功构造出的二叉树。
相关练习请转到:【例题】