数据结构 第六章 树与二叉树(三)

🚀 【考纲要求】二叉树的遍历

🚀 第六章第一节内容请查看此链接 树的基本概念

🚀 第六章第二节内容请查看此链接 二叉树的定义、四种特殊的二叉树和二叉树的存储结构

三、二叉树的遍历和线索二叉树

3.1二叉树的遍历

所谓的二叉树的遍历就是将按着某种顺序依次的遍历二叉树中的节点

①先序遍历

先序遍历就是按着根节点------左孩子节点------右孩子节点的顺序依次往下遍历

②中序遍历

是按着左孩子------根节点------右孩子的顺序遍历的

③后续遍历

按着左孩子------右孩子------根节点的顺序遍历



应该熟练的掌握这三种遍历的顺序,能够准确得出每种方法的遍历顺序。在遍历中我们还可以利用这些算法来求前缀、中缀和后缀表达式,使用先序遍历可以得到前缀表达式,使用中序遍历可以得到中缀表达式,使用后序遍历可以得到后缀表达式。

如何使用代码来表示这三种遍历顺序呢?其实就是使用了递归来实现遍历的,遍历之前要判断此时的根节点是否为空,即是否为空树,若不为空树就继续依次按着三种不同的访问顺序编写代码即可。

c 复制代码
//先序遍历
void PreOrder(BiTree T){
	if(T!==NULL){
		visit(T);        //访问根节点
		PreOrder(T->Lchild);  //访问左孩子
		PreOrder(T->Rchild);  //访问右孩子
	}
}
c 复制代码
//中序遍历
void PreOrder(BiTree T){
	if(T!==NULL){
		PreOrder(T->Lchild);  //访问左孩子
		visit(T);        //访问根节点
		PreOrder(T->Rchild);  //访问右孩子
	}
}
c 复制代码
//后序遍历
void PreOrder(BiTree T){
	if(T!==NULL){
		PreOrder(T->Lchild);  //访问左孩子
		PreOrder(T->Rchild);  //访问右孩子
		visit(T);        //访问根节点
	}
}

④层序遍历

就是按着树的结构一层一层的遍历,对于这种方式的遍历我们是使用了一个队列进行辅助遍历的。

具体来看下它是怎么进行遍历的,首先判断是否为空树,树不为空,则将树的根节点首先入队;然后判断队列是否为空,若不为空则出队一个元素,与此同时判断出队元素的是否存在左孩子和右孩子,按着先入队左孩子再入队右孩子的顺序入队;入队操作结束后依次循环判队列空,出队一个元素,入队出对元素的左右孩子,值至队列空,遍历即可以完成。

⑤递归算法和非递归算法的转换

⑥由遍历序列构造二叉树

3.2线索二叉树

相关推荐
2301_803554527 分钟前
正向代理,反向代理,负载均衡还有nginx
java·nginx·负载均衡
要开心吖ZSH8 分钟前
软件设计师备考-(十六)数据结构及算法应用(重要)
java·数据结构·算法·软考·软件设计师
向上的车轮16 分钟前
基于Java Spring Boot的云原生TodoList Demo 项目,验证云原生核心特性
java·spring boot·云原生
程序员清风18 分钟前
快手一面:为什么要求用Static来修饰ThreadLocal变量?
java·后端·面试
逍遥德19 分钟前
Java8 Comparator接口 和 List Steam 排序使用案例
java·spring boot·list·排序算法
带娃的IT创业者21 分钟前
如何开发一个教育性质的多线程密码猜测演示器
网络·python·算法
前行的小黑炭37 分钟前
Android :如何快速让布局适配手机和平板?
android·java·kotlin
zhong liu bin2 小时前
MySQL数据库面试题整理
数据结构·数据库·mysql
_BugMan2 小时前
【IDEA】干活?一个IDEA即可,集成开发平台打造攻略
java·ide·intellij-idea
Aczone282 小时前
硬件(六)arm指令
开发语言·汇编·arm开发·嵌入式硬件·算法