【教程】已知二叉树的后序序列和中序序列构造二叉树

原理:
二叉树的后序序列遍历过程是:左→右→根。中序序列遍历过程是:左→根→右。
已知后序序列可以唯一确定根结点,即:后序序列的最后一个结点就是根结点。确定完根结点之后,根据中序序列可以确定根结点的左子树和右子树,即:在中序序列中根结点的左边是左子树,根结点的右边是右子树。


例题:
已知某二叉树的后序序列为GDBEFCA,中序序列为DGBAECF,则构造该二叉树的过程如下图。


【教程】已知二叉树的后序序列和中序序列构造二叉树_第1张图片


详细过程如下:
step1:后序序列为GDBEFCA,中序序列为DGBAECF
            可以得到:A是该二叉树根结点,DGB是A结点的左子树,ECF是A结点的右子树。
            如图:
【教程】已知二叉树的后序序列和中序序列构造二叉树_第2张图片
step2:先看左子树:DGB,分析它。
            从二叉树的后序序列 GDBEFCA 中找到DGB按照二叉树的后序序列中的顺序写出来,即:GDB
            它就是左子树DGB的后序序列。再从二叉树的中序序列 DGBAECF 中找到DGB按照二叉树的中
            序序列中的顺序写出来,即:DGB它就是左子树DGB的中序序列。
            于是有,左子树DGB的后序序列为:GDB,中序序列为:DGB
            可以得到:B是根结点,DG是B结点的左子树
            如图:
【教程】已知二叉树的后序序列和中序序列构造二叉树_第3张图片
step3:再看左子树:DG,分析它。
            从二叉树的后序序列 GDBEFCA 中找到DG按照二叉树的后序序列中的顺序写出来,即:GD它就
            是左子树DG的后序序列。再从二叉树的中序序列 DGBAECF 中找到DG按照二叉树的中序序列中
            的顺序写出来,即:DG它就是左子树DG的中序序列。
            于是有,左子树DG的后序序列为:GD,中序序列为:DG
            可以得到:D是根结点,G是B结点的右子树。
            如图:
【教程】已知二叉树的后序序列和中序序列构造二叉树_第4张图片
至此A结点的左子树分析完毕,接下来是右子树。


step1:从二叉树的后序序列 GDBEFCA 中找到ECF按照二叉树的后序序列中的顺序写出来,即:EFC它
            就是右子树ECF的后序序列。再从二叉树的中序序列 DGBAECF 中找到ECF按照二叉树的中序序
            列中的顺序写出来,即:ECF它就是右子树ECF的中序序列。
            于是有,右子树ECF的后序序列为:EFC,中序序列为:ECF
            可以得到:C是根结点,E是C结点的左子树,F是C结点的右子树
            如图:
【教程】已知二叉树的后序序列和中序序列构造二叉树_第5张图片
以上就是根据二叉树的先序序列和中序序列成功构造出的二叉树。

相关练习请转到:【例题】

你可能感兴趣的:(数据结构)