内容简介:上一篇 我们简单介绍了什么是二叉查找树,并实现了该结构。这一篇我们来看如何遍历二叉树。常用的三种遍历方式有“先序” “中序” “后序”。对于二次查找树来说,中序遍历刚好可以得到一个有序的结果(即排序)。三种遍历方式的定义如下从根结点出发,逆时针(访问左子树)沿着二叉树外缘移动,对每个结点均途径三次,最后回到根结点。
上一篇 我们简单介绍了什么是二叉查找树,并实现了该结构。
这一篇我们来看如何遍历二叉树。常用的三种遍历方式有“先序” “中序” “后序”。对于二次查找树来说,中序遍历刚好可以得到一个有序的结果(即排序)。三种遍历方式的定义如下
从根结点出发,逆时针(访问左子树)沿着二叉树外缘移动,对每个结点均途径三次,最后回到根结点。
- 先序:访问结点均是第一次经过结点时进行的(根节点 -> 左节点 -> 右节点)。
- 中序:访问结点均是第二次经过结点时进行的(左节点 -> 根节点 -> 右节点)。
- 后序:访问结点均是第三次经过结点时进行的(左节点 -> 右节点 -> 根节点)。
是不是看了云里雾里,没关系,我们来画个图,注意箭头方向
有两个子节点的好理解一点,像节点 D 只有一个节点是I,那这种到底是先D 还是先I,还是搞不明白。那我们再画一人图,注意数字。
上一个图的基础上,结合上一遍 的节点的实现,所有节点都有两个子节点,只不过有的子节点的是null。我们为所有没有两个叶子节点的节点以空节点来补齐两个。
这样子是不是很清晰了。
接下来我们把这个思路转化为代码实现。
public function preOrder()
{
$stack = [];
// 先访问根结点
$current = $this->root;
$pre = [];
while (!empty($stack) || $current != null) {
// 访问左子树
while ($current != null) {
$pre[] = $current->data;
$stack[] = $current;
$current = $current->left;
}
$current = array_pop($stack);
// 访问右子树
$current = $current->right;
}
return $pre;
}
public function inOrder()
{
$stack = [];
// 先访问根结点
$current = $this->root;
$sort = [];
while (!empty($stack) || $current != null) {
// 访问左子树
while ($current != null) {
$stack[] = $current;
$current = $current->left;
}
$current = array_pop($stack);
$sort[] = $current->data;
// 访问右子树
$current = $current->right;
}
return $sort;
}
public function postOrder()
{
$stack = [];
$visitStack = [];
$current = $this->root;
while ($current != null) {
$visitStack[] = $current;
if ($current->left != null) {
$stack[] = $current->left;
}
if ($current->right != null) {
$stack[] = $current->right;
}
$current = array_pop($stack);
}
$next = [];
while ($current = array_pop($visitStack)) {
$next[] = $current->data;
}
return $next;
}
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- 数据结构-二叉树遍历
- 数据结构基础:根据先序、中序遍历结果构造二叉树
- 【图解数据结构】 一组动画彻底理解二叉树三种遍历
- 数据结构 2 字符串 数组、二叉树以及二叉树的遍历
- 数组常见的遍历循环方法、数组的循环遍历的效率对比
- C++拾趣——STL容器的插入、删除、遍历和查找操作性能对比(Windows VirtualStudio)——遍历和删除
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Docker从入门到实战
黄靖钧 / 机械工业出版社 / 2017-6 / 69.00元
本书从Docker的相关概念与基础知识讲起,结合实际应用,通过不同开发环境的实战例子,详细介绍了Docker的基础知识与进阶实战的相关内容,以引领读者快速入门并提高。 本书共19章,分3篇。第1篇容器技术与Docker概念,涵盖的内容有容器技术、Docker简介、安装Docker等。第2篇Docker基础知识,涵盖的内容有Docker基础、Docker镜像、Dockerfile文件、Dock......一起来看看 《Docker从入门到实战》 这本书的介绍吧!