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节点. 我们使用 ...
随机推荐
- vue培训记录
在公司做了一次vue相关的培训,自己整理了一些大纲.供大家参考学习! ### 1. 项目构成及原理 [Vue](https://cn.vuejs.org/)###* 主流框架见解及差别 * react ...
- Oracle PL/SQL学习之你需要知道的快捷键
1.格式化sql语句 Ctrl+A 然后 Ctrl+F7 2.窗口最大化最小化 首选项-->快捷键-->Maximize Toggle,然后修改成自己熟悉的快捷键设置.
- C#找出接口的所有实现类并遍历执行这些类的公共方法
//这里找出了实现IOutputArray接口的所有类 private void FindAllClass() { var types = AppDomain.CurrentDomain.GetAss ...
- Ubuntu16.04安装视觉SLAM环境(ceres-solver)
1.先在github上下载ceres-solver git clone https://github.com/ceres-solver/ceres-solver.git 2.安装ceres-solve ...
- java设计模式:简单实现生产者和消费者模式
*博客搬家:初版发布于 2016/04/15 20:31 原博客地址:https://my.oschina.net/sunqinwen/blog/660881 本实例中单独为生产者和消费者各开辟 ...
- flask开发笔记
目录 虚拟环境 Debug模式 配置文件 url传入参数 url反转 重定义向 模板 创建 jinjia2语法 模板继承 flash 加载静态文件 MySQL数据库命令 配置 更新.提交.删除 模型操 ...
- ASP.NET Core中Middleware的使用
https://www.cnblogs.com/shenba/p/6361311.html ASP.NET 5中Middleware的基本用法 在ASP.NET 5里面引入了OWIN的概念,大致意 ...
- 转 oracle ASM中ASM_POWER_LIMIT参数
https://daizj.iteye.com/blog/1753434 ASM_POWER_LIMIT 该初始化参数用于指定ASM例程平衡磁盘所用的最大权值,其数值范围为0~11,默认值为1.该初始 ...
- 10g 升级到11g 失效对象2则
########SAMPLE 0 Invalid X_$ Views & Synonyms After Upgrading to 11g (文档 ID 878623.1) Those view ...
- [转]Hive 数据类型
Hive的内置数据类型可以分为两大类:(1).基础数据类型:(2).复杂数据类型.其中,基础数据类型包括:TINYINT,SMALLINT,INT,BIGINT,BOOLEAN,FLOAT,DOUBL ...