推导二叉树遍历结果

已知一棵二叉树的先序遍历序列为:ABCDEF,中序遍历序列为CBAEDF,求后序遍历结果。

先序为:ABCDEF,所以A为根结点。又中序为:CBAEDF,所以C、B为A的左子树结点,E、D、F是A的右子树的结点。

《推导二叉树遍历结果》

再看先序:ABCDEF,打印A之后接着打印B,所以B是A的左孩子。再看中序:CBAEDF,C于B之前打印,所以C是B的左孩子。

《推导二叉树遍历结果》

看先序:ABCDEF,结合上图可知D是A的右孩子。再看中序:CBAEDF,所以E是D的左孩子,F是D的右孩子。最终得到的二叉树如下:

《推导二叉树遍历结果》

为避免推导失误,可以检查一遍所得二叉树的先序和中序遍历。最后由所得二叉树得到后序遍历:CBEFDA。

二叉树遍历有如下性质:

已知先序和中序遍历序列,可以唯一确定一棵二叉树;

已知后序和中序遍历序列,可以唯一确定一棵二叉树;

已知先序和后序遍历序列,不能唯一确定一棵二叉树。

Reference:

[1] 《大话数据结构》

 

    原文作者:算法小白
    原文地址: https://www.cnblogs.com/zhuyf87/archive/2012/11/03/2753015.html
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞