c++中二叉树的先序中序后序遍历

c++中二叉树的先(前)序、中序、后序遍历 讲解版

 

首先先看一个遍历的定义(源自度娘):

所谓遍历(Traversal),是指沿着某条搜索路线,依次对树中每个结点均做一次且仅做一次访问。访问结点所做的操作依赖于具体的应用问题。 遍历是二叉树上最重要的运算之一,是二叉树上进行其它运算之基础。当然遍历的概念也适合于多元素集合的情况,如数组。

树的遍历是树的一种重要的运算。所谓遍历是指对树中所有结点的信息的访问,即依次对树中每个结点访问一次且仅访问一次。树的3种最重要的遍历方式分别称为前序遍历、中序遍历和后序遍历。以这3种方式遍历一棵树时,若按访问结点的先后次序将结点排列起来,就可分别得到树中所有结点的前序列表、中序列表和后序列表。相应的结点次序分别称为结点的前序、中序和后序。

--------------------------------------------------------------------------------------------------------------------------

当然,百度上给的解释太专业,先看一个图:

这是一颗二叉树,它的遍历。首先你要明确树的基本组成:根结点、叶结点、父结点、子结点。

前序遍历

前序遍历(DLR),是二叉树遍历的一种,也叫做先根遍历、先序遍历、前序周游,可记做根左右。前序遍历首先访问根结点然后遍历左子树,最后遍历右子树。

前序遍历就是类似dfs的方式,从根结点一直从左子树向下直到叶结点,然后返回到叶结点的父亲,再从其父结点的右子树向下。

中序遍历

中序遍历(LDR)是二叉树遍历的一种,也叫做中根遍历、中序周游。在二叉树中,先左后根再右。巧记:左根右。

中序遍历是先访问左儿子---父亲---右儿子。

后序遍历

后序遍历(LRD)是二叉树遍历的一种,也叫做后根遍历、后序周游,可记做左右根。后序遍历有递归算法和非递归算法两种。在二叉树中,先左后右再根。巧记:左右根。

后序遍历是先访问左儿子---右儿子---父亲。

---------------------------------------------------------------------------------------------------------------------------------

总结

其实这三种遍历方法差不了太多,前中后的意思是父结点的访问顺序不一样,只是最后结果有些差别,没有什么特别需要这三种方法的题。只是输入输出和程序中为了方便而起的名字。

 

 

小练习

对于这个图,它的

前序遍历:A---B---D---E---G---J---H---C---F---I---K---L

中序遍历:D---B---J---G---E---H---A---C(f为右结点)---K---I---L---F

后序遍历:D---J---G---H---E---B---K---L---I---F---C---A

posted @ 2018-02-10 23:06  欢语_暗影  阅读(3120)  评论(0编辑  收藏  举报