二叉树的遍历及应用

-先序遍历:

访问根结点,先序遍历其左子树,先序遍历其右子树;运用到递归
void PreOrderTraversal ( BinTree BT )
{
if ( BT )
{
printf ( “%d”, BT -> Data );
PreOrderTraversal ( BT -> Left );
PreOrderTraversal ( BT -> Right );
}
}

-中序遍历:

中序遍历其左子树,访问根结点,中序遍历其右子树
void InOrderTraversal ( BinTree BT )
{
if ( BT )
{
InOrderTraversal ( BT -> Left );
printf ( “%d”, BT -> Data );
InOrderTraversal ( BT -> Right );
}
}

-后序遍历:

后序遍历其左子树,后序遍历其右子树,访问根结点
void PostOrderTraversal ( BinTree BT )
{
if ( BT )
{
PostOrderTraversal ( BT -> Left );
PostOrderTraversal ( BT -> Right );
printf ( “%d”, BT -> Data );
}
}

三种遍历过程中经过的结点的路线一样,只是访问各结点的时机不同,先序中序后序分别对应第一次访问时printfData第二次访问printfData和第三访问printfData

上面三种方法都是用递归,而递归根本实现方法是堆栈,现在我们直接用堆栈来实现非递归的遍历算法

eg:中序遍历非递归遍历算法:
1.遇到一个结点 就把它压栈 并去遍历它的左子树
2.当左子树遍历结束后 从栈顶弹出这个结点并访问它
3.然后按其右指针再去中序遍历该结点的右子树

void InOrderTraversal( BinTree BT ){
Stack s = CreateStack ( MaxSize ) // 创建并初始化堆栈s
while( T | | !IsEmpty(s) ){
while(T){ // 一直向左并将沿途结点压入堆栈
Push ( S, T );
T = T -> Left;
}
if ( !IsEmpty(s) ){
T = Pop(s); // 结点弹出堆栈
printf(“]”, T -> Data); //(访问)打印结点
T = T -> Right; //转向右子树
}
}

-层序遍历:

二叉树遍历的核心问题:二维结构的线性化
一个结点有两个关联(左儿子和右儿子)通过一个结点访问到一个关联结点(左儿子)后另一个关联结点(右儿子)怎么办?这个结点本身怎么办?这就需要将二维结构线性化。
解决方案:需要一个存储结构保存暂时不访问的结点 存储结构:堆栈、队列

队列实现:遍历从根结点开始 首先将根结点入队 然后开始执行循环:结点出队、访问该结点、其左右儿子入队(注意队列中先进先出原则)
序列特征:一层一层访问的
步骤:
1.从队列中取出一个元素;2.访问该元素所指结点;3.若该元素所指结点的左右儿子结点非空 则将其左右儿子的指针顺序入队。
void LevelOrderTraversal( BinTree BT ){
Queue Q ; BinTree T ;
if ( !BT ) return ; //若是空树直接返回
Q = CreateQueue ( MaxSize ) ; //创建并初始化Q
AddQ( Q, BT ) ;
while( ! IsEmptyQ ( Q ) ){
T = DeleteQ ( Q ) ;
printf ( “%d\n” , T -> Data ) ; //访问取出队列的结点
if ( T -> Left ) AddQ( Q, T -> Left );
if ( T -> Right ) AddQ( Q, T -> Right );
}
}

-遍历二叉树的应用:

eg:输出二叉树中的叶子结点,利用先序遍历(中序后序类似)
void PreOrderTraversal ( BinTree BT )
{
if ( BT )
{
if( !BT -> Left && !BT -> Right )
printf ( “%d”, BT -> Data );
PreOrderTraversal ( BT -> Left );
PreOrderTraversal ( BT -> Right );
}
}

eg:求二叉树的高度
void PostOrderGetHeight ( BinTree BT )
{ int HL, HR, MaxH ;
if ( BT )
{
HL = PostOrderGetHeight ( BT -> Left ); // 求左子树的深度
HR = PostOrderGetHeight ( BT -> Right ); //求右子树的深度
MaxH = ( HL > HR ) ? HL : HR ; //取左右子树较大的深度
return ( MaxH + 1 ); //返回树的深度
}
else return 0; // 空树深度为0
}

eg:二元运算表达式树及其遍历:

002WV0d1zy70G86PztF03&690.png

先序遍历得到前缀表达式:++a*b c*+*d e f g
中缀表达式会受到运算符优先级的影响,需要在遍历时加括号
后序遍历得到后缀表达式:a b c*+d e*f+g*+

eg:由两种遍历序列确定二叉树
(必须知道中序二叉树,若只是知道前序和后序遍历 无法确定该二叉树)
已知先序和中序遍历序列 来确定一棵二叉树
步骤:
根据先序遍历序列第一个结点 确定根结点
根据根结点在中序遍历序列中分割出左右两个子序列
对左子树和右子树分别递归使用相同的方法继续分解
practice:先序序列:a bcdefghij
中序序列:cbed a hgijf
由先序序列可知根结点为a,通过中序序列可知a左边为左子树 a右边为右子树,以此类推可确定二叉树

类似地,已知后序和中序遍历序列也可以确定一棵二叉树

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,425评论 4 361
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,058评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,186评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,848评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,249评论 3 286
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,554评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,830评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,536评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,239评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,505评论 2 244
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,004评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,346评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,999评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,060评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,821评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,574评论 2 271
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,480评论 2 267

推荐阅读更多精彩内容

  • 数据结构和算法--二叉树的实现 几种二叉树 1、二叉树 和普通的树相比,二叉树有如下特点: 每个结点最多只有两棵子...
    sunhaiyu阅读 6,336评论 0 14
  • 编译环境:python v3.5.0, mac osx 10.11.4 前述内容: 线性表 队列 堆栈 线性结构...
    掷骰子的求阅读 2,363评论 1 7
  • 姓名: 李小娜 [嵌牛导读] :这篇文章主要介绍了Java二叉排序树,包括二叉排序树的定义、二叉排序树的性质、二叉...
    n184阅读 582评论 0 0
  • 树和二叉树 1、树的定义 树(Tree)是由一个 或 多个结点 组成的有限集合T,且满足: ①有且仅有一个称为根的...
    利伊奥克儿阅读 1,276评论 0 1
  • 1,从本篇文章/ 音频/ 视频中我学到的最重要的概念:It is impossible to learn a la...
    133宋双芳阅读 136评论 2 0