二叉树的先序、中序、后序遍历


先(根)序遍历(根左右):A B D H E I C F J K G
中(根)序遍历(左根右):D H B E I A J F K C G
后(根)序遍历(左右根):H D I E B J K F G C A

例子1:已知二叉树的后序遍历序列是dabec,中序遍历序列是debac,它的前序遍历序列是(cedba)
(1)中序遍历:debac
后序遍历:dabec
后序遍历序列的最后一个结点是根结点,所以可知c为根结点。
中序遍历序列的根结点在中间,其左边是左子树,右边是右子树。所以从中序遍历序列中可看出,根结点c只有左子树,没有右子树。

(2)中序遍历:deba
后序遍历:dabe
后序遍历序列的最后一个结点是根结点,所以可知e为c的左子树的根结点。
中序遍历序列的根结点在中间,其左边是左子树,右边是右子树。所以从中序遍历序列中可看出,根结点e的左子结点是d,右子树是ba。

(3)中序遍历:ba
后序遍历:ab
由后序遍历序列可知b为e的右子树的根结点。由中序遍历序列中可看出,a为根结点b的右子结点。

例子2:已知二叉树的前序遍历序列是abdgcefh,中序遍历序列是dgbaechf,它的后序遍历序列是(gdbehfca)。
(1)先序遍历:abdgcefh
中序遍历:dgbaechf
先序遍历序列的第一个结点是根结点,所以可知a为根结点。
中序遍历序列的根结点在中间,其左边是左子树,右边是右子树。所以从中序遍历序列中可看出,根结点a的左子树是dgb,右子树是echf。

a的左子树:
(2)先序遍历:bdg
中序遍历:dgb
先序遍历序列的第一个结点是根结点,所以可知b为a的左子树的根结点。
中序遍历序列的根结点在中间,其左边是左子树,右边是右子树。所以从中序遍历序列中可看出,根结点b的左子树是dg,没有右子树。

b的左子树:
(3)先序遍历:dg
中序遍历:dg
由先序遍历序列可知d为b的左子树的根结点。
中序遍历序列的根结点在中间,其左边是左子树,右边是右子树。所以从中序遍历序列中可看出,根结点d的右子结点是g。

a的右子树:
(4)先序遍历:cefh
中序遍历:echf
由先序遍历序列可知c为a的右子树的根结点。
从中序遍历序列中可看出,根结点c的左子结点是e,右子树是hf。

c的右子树:
(5)先序遍历:fh
中序遍历:hf
由先序遍历序列可知f为c的右子树的根结点。
从中序遍历序列中可看出,根结点f的左子结点是h,没有右子树。

https://blog.csdn.net/qq_34840129/article/details/80619761


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM