php编程--二叉树遍历算法实现
今天使用php来实现二叉树的遍历
创建的二叉树如下图所示
php代码如下所示:
- <?php
- class Node {
- public $value;
- public $child_left;
- public $child_right;
- }
- final class Ergodic {
- //前序遍历:先访问根节点,再遍历左子树,最后遍历右子树;并且在遍历左右子树时,仍需先遍历根节点,然后访问左子树,最后遍历右子树
- public static function preOrder($root){
- $stack = array();
- array_push($stack, $root);
- while(!empty($stack)){
- $center_node = array_pop($stack);
- echo $center_node->value . ' ';
- //先把右子树节点入栈,以确保左子树节点先出栈
- if($center_node->child_right != null) array_push($stack, $center_node->child_right);
- if($center_node->child_left != null) array_push($stack, $center_node->child_left);
- }
- }
- //中序遍历:先遍历左子树、然后访问根节点,最后遍历右子树;并且在遍历左右子树的时候。仍然是先遍历左子树,然后访问根节点,最后遍历右子树
- public static function midOrder($root){
- $stack = array();
- $center_node = $root;
- while (!empty($stack) || $center_node != null) {
- while ($center_node != null) {
- array_push($stack, $center_node);
- $center_node = $center_node->child_left;
- }
- $center_node = array_pop($stack);
- echo $center_node->value . ' ';
- $center_node = $center_node->child_right;
- }
- }
- //后序遍历:先遍历左子树,然后遍历右子树,最后访问根节点;同样,在遍历左右子树的时候同样要先遍历左子树,然后遍历右子树,最后访问根节点
- public static function endOrder($root){
- $push_stack = array();
- $visit_stack = array();
- array_push($push_stack, $root);
- while (!empty($push_stack)) {
- $center_node = array_pop($push_stack);
- array_push($visit_stack, $center_node);
- //左子树节点先入$pushstack的栈,确保在$visitstack中先出栈
- if ($center_node->child_left != null) array_push($push_stack, $center_node->child_left);
- if ($center_node->child_right != null) array_push($push_stack, $center_node->child_right);
- }
- while (!empty($visit_stack)) {
- $center_node = array_pop($visit_stack);
- echo $center_node->value . ' ';
- }
- }
- }
- //创建二叉树
- $a = new Node();
- $b = new Node();
- $c = new Node();
- $d = new Node();
- $e = new Node();
- $f = new Node();
- $g = new Node();
- $h = new Node();
- $i = new Node();
- $a->value = 'A';
- $b->value = 'B';
- $c->value = 'C';
- $d->value = 'D';
- $e->value = 'E';
- $f->value = 'F';
- $g->value = 'G';
- $h->value = 'H';
- $i->value = 'I';
- $a->child_left = $b;
- $a->child_right = $c;
- $b->child_left = $d;
- $b->child_right = $g;
- $c->child_left = $e;
- $c->child_right = $f;
- $d->child_left = $h;
- $d->child_right = $i;
- //前序遍历
- Ergodic::preOrder($a); //结果是:A B D H I G C E F
- echo '<br/>';
- //中序遍历
- Ergodic::midOrder($a); //结果是: H D I B G A E C F
- echo '<br/>';
- //后序遍历
- Ergodic::endOrder($a); //结果是: H I D G B E F C A
php编程--二叉树遍历算法实现的更多相关文章
- python实现二叉树遍历算法
说起二叉树的遍历,大学里讲的是递归算法,大多数人首先想到也是递归算法.但作为一个有理想有追求的程序员.也应该学学非递归算法实现二叉树遍历.二叉树的非递归算法需要用到辅助栈,算法着实巧妙,令人脑洞大开. ...
- 树和二叉树->遍历
文字描述 二叉树的先根遍历 若二叉树为空,则空操纵,否则 (1) 访问根结点 (2) 先根遍历左子树 (3) 先根遍历右子树 二叉树的中根遍历 若二叉树为空,则空操纵,否则 (1) 中根遍历左子树 ( ...
- java数据结构之二叉树遍历的非递归实现
算法概述递归算法简洁明了.可读性好,但与非递归算法相比要消耗更多的时间和存储空间.为提高效率,我们可采用一种非递归的二叉树遍历算法.非递归的实现要借助栈来实现,因为堆栈的先进后出的结构和递归很相似.对 ...
- javascript数据结构与算法--二叉树遍历(后序)
javascript数据结构与算法--二叉树遍历(后序) 后序遍历先访问叶子节点,从左子树到右子树,再到根节点. /* *二叉树中,相对较小的值保存在左节点上,较大的值保存在右节点中 * * * */ ...
- javascript数据结构与算法--二叉树遍历(先序)
javascript数据结构与算法--二叉树遍历(先序) 先序遍历先访问根节点, 然后以同样方式访问左子树和右子树 代码如下: /* *二叉树中,相对较小的值保存在左节点上,较大的值保存在右节点中 * ...
- javascript数据结构与算法--二叉树遍历(中序)
javascript数据结构与算法--二叉树遍历(中序) 中序遍历按照节点上的键值,以升序访问BST上的所有节点 代码如下: /* *二叉树中,相对较小的值保存在左节点上,较大的值保存在右节点中 * ...
- 算法随笔-二叉树遍历的N种姿势
最近在练习用Python刷算法,leetcode上刷了快300题.一开始怀疑自己根本不会写代码,现在觉得会写一点点了,痛苦又充实的刷题历程.对我这种半路出家的人而言,收获真的很大. 今天就从二叉树遍历 ...
- 《数据结构与算法(C语言版)》严蔚敏 | 第五章 建立二叉树,并完成三/四种遍历算法
PS:所有的代码示例使用的都是这个图 2019-10-29 利用p126的算法5.3建立二叉树,并完成三种遍历算法 中序 后序 先序 #include<iostream> #include ...
- Python -二叉树 创建与遍历算法(很详细)
树表示由边连接的节点.它是一个非线性的数据结构.它具有以下特性. 一个节点被标记为根节点. 除根节点之外的每个节点都与一个父节点关联. 每个节点可以有一个arbiatry编号的chid节点. 我们使用 ...
随机推荐
- expect分发脚本
[分发系统]yum -y install expect #!/usr/bin/expect set host "192.168.11.102" " spawn ssh r ...
- 常见浏览器hack汇总
1.背景渐变bug: ①.ie8 ie9:用滤镜的方式解决: -ms-filter:"progid:DXImageTransform.Microsoft.gradient(GradientT ...
- 洛谷 P5249 [LnOI2019]加特林轮盘赌 题解【概率期望】【DP】
很有意思的题目. 题目背景 加特林轮盘赌是一个养生游戏. 题目描述 与俄罗斯轮盘赌等手枪的赌博不同的是,加特林轮盘赌的赌具是加特林. 加特林轮盘赌的规则很简单:在加特林的部分弹夹中填充子弹.游戏的参加 ...
- git泄露利用脚本
留一下万一之后用得着呢 工作原理 1.解析.git/index文件,找到工程中所有的: ( 文件名,文件sha1 ) 2.去.git/objects/ 文件夹下下载对应的文件 3.zlib解压文件,按 ...
- float 浮动 文档流和文字流区别
关于float属性的脱离文档流的问题 使用float浮动后,元素虽然会脱离文档流,但还处在文本流的位置当中,所以就不会出现重叠的效果吗? 下面我自己试了一下,给两个DIV分别设置了样式,而只给第一个D ...
- Python编程中报过的错
一.TypeError: not all arguments converted during string formatting def max(*args): print('max2:%s' % ...
- selenium+Python(生成html测试报告)
当自动化测试完成后,我们需要一份漂亮且通俗易懂的测试报告来展示自动化测试成果,仅仅一个简单的log文件是不够的 HTMLTestRunner是Python标准库unittest单元测试框架的一个扩展, ...
- MySql的存储引擎介绍
下面主要介绍InnoDB.MyISAM和MEMEORY三种存储引擎. InnoDB存储引擎 InnoDB遵循CNU通用公开许可(GPL)发行.InnoDB已经被一些重量级互联网公司所采用,如雅虎.Sl ...
- Spark中自定义累加器Accumulator
1. 自定义累加器 自定义累加器需要继承AccumulatorParam,实现addInPlace和zero方法. 例1:实现Long类型的累加器 object LongAccumulatorPara ...
- linux系统修改route路由
linux下静态路由修改命令方法一:添加路由route add -net 192.168.0.0/24 gw 192.168.0.1route add -host 192.168.1.1 dev 19 ...