今天使用php来实现二叉树的遍历

创建的二叉树如下图所示

php代码如下所示:

  1.  
    <?php
  2.  
    class Node {
  3.  
    public $value;
  4.  
    public $child_left;
  5.  
    public $child_right;
  6.  
    }
  7.  
    final class Ergodic {
  8.  
    //前序遍历:先访问根节点,再遍历左子树,最后遍历右子树;并且在遍历左右子树时,仍需先遍历根节点,然后访问左子树,最后遍历右子树
  9.  
    public static function preOrder($root){
  10.  
    $stack = array();
  11.  
    array_push($stack, $root);
  12.  
    while(!empty($stack)){
  13.  
    $center_node = array_pop($stack);
  14.  
    echo $center_node->value . ' ';
  15.  
     
  16.  
    //先把右子树节点入栈,以确保左子树节点先出栈
  17.  
    if($center_node->child_right != null) array_push($stack, $center_node->child_right);
  18.  
    if($center_node->child_left != null) array_push($stack, $center_node->child_left);
  19.  
    }
  20.  
    }
  21.  
    //中序遍历:先遍历左子树、然后访问根节点,最后遍历右子树;并且在遍历左右子树的时候。仍然是先遍历左子树,然后访问根节点,最后遍历右子树
  22.  
    public static function midOrder($root){
  23.  
    $stack = array();
  24.  
    $center_node = $root;
  25.  
    while (!empty($stack) || $center_node != null) {
  26.  
    while ($center_node != null) {
  27.  
    array_push($stack, $center_node);
  28.  
    $center_node = $center_node->child_left;
  29.  
    }
  30.  
     
  31.  
    $center_node = array_pop($stack);
  32.  
    echo $center_node->value . ' ';
  33.  
     
  34.  
    $center_node = $center_node->child_right;
  35.  
    }
  36.  
    }
  37.  
    //后序遍历:先遍历左子树,然后遍历右子树,最后访问根节点;同样,在遍历左右子树的时候同样要先遍历左子树,然后遍历右子树,最后访问根节点
  38.  
    public static function endOrder($root){
  39.  
    $push_stack = array();
  40.  
    $visit_stack = array();
  41.  
    array_push($push_stack, $root);
  42.  
     
  43.  
    while (!empty($push_stack)) {
  44.  
    $center_node = array_pop($push_stack);
  45.  
    array_push($visit_stack, $center_node);
  46.  
    //左子树节点先入$pushstack的栈,确保在$visitstack中先出栈
  47.  
    if ($center_node->child_left != null) array_push($push_stack, $center_node->child_left);
  48.  
    if ($center_node->child_right != null) array_push($push_stack, $center_node->child_right);
  49.  
    }
  50.  
     
  51.  
    while (!empty($visit_stack)) {
  52.  
    $center_node = array_pop($visit_stack);
  53.  
    echo $center_node->value . ' ';
  54.  
    }
  55.  
    }
  56.  
    }
  57.  
     
  58.  
     
  59.  
    //创建二叉树
  60.  
    $a = new Node();
  61.  
    $b = new Node();
  62.  
    $c = new Node();
  63.  
    $d = new Node();
  64.  
    $e = new Node();
  65.  
    $f = new Node();
  66.  
    $g = new Node();
  67.  
    $h = new Node();
  68.  
    $i = new Node();
  69.  
     
  70.  
    $a->value = 'A';
  71.  
    $b->value = 'B';
  72.  
    $c->value = 'C';
  73.  
    $d->value = 'D';
  74.  
    $e->value = 'E';
  75.  
    $f->value = 'F';
  76.  
    $g->value = 'G';
  77.  
    $h->value = 'H';
  78.  
    $i->value = 'I';
  79.  
     
  80.  
    $a->child_left = $b;
  81.  
    $a->child_right = $c;
  82.  
    $b->child_left = $d;
  83.  
    $b->child_right = $g;
  84.  
    $c->child_left = $e;
  85.  
    $c->child_right = $f;
  86.  
    $d->child_left = $h;
  87.  
    $d->child_right = $i;
  88.  
     
  89.  
     
  90.  
    //前序遍历
  91.  
    Ergodic::preOrder($a); //结果是:A B D H I G C E F
  92.  
    echo '<br/>';
  93.  
    //中序遍历
  94.  
    Ergodic::midOrder($a); //结果是: H D I B G A E C F
  95.  
    echo '<br/>';
  96.  
    //后序遍历
  97.  
    Ergodic::endOrder($a); //结果是: H I D G B E F C A

php编程--二叉树遍历算法实现的更多相关文章

  1. python实现二叉树遍历算法

    说起二叉树的遍历,大学里讲的是递归算法,大多数人首先想到也是递归算法.但作为一个有理想有追求的程序员.也应该学学非递归算法实现二叉树遍历.二叉树的非递归算法需要用到辅助栈,算法着实巧妙,令人脑洞大开. ...

  2. 树和二叉树->遍历

    文字描述 二叉树的先根遍历 若二叉树为空,则空操纵,否则 (1) 访问根结点 (2) 先根遍历左子树 (3) 先根遍历右子树 二叉树的中根遍历 若二叉树为空,则空操纵,否则 (1) 中根遍历左子树 ( ...

  3. java数据结构之二叉树遍历的非递归实现

    算法概述递归算法简洁明了.可读性好,但与非递归算法相比要消耗更多的时间和存储空间.为提高效率,我们可采用一种非递归的二叉树遍历算法.非递归的实现要借助栈来实现,因为堆栈的先进后出的结构和递归很相似.对 ...

  4. javascript数据结构与算法--二叉树遍历(后序)

    javascript数据结构与算法--二叉树遍历(后序) 后序遍历先访问叶子节点,从左子树到右子树,再到根节点. /* *二叉树中,相对较小的值保存在左节点上,较大的值保存在右节点中 * * * */ ...

  5. javascript数据结构与算法--二叉树遍历(先序)

    javascript数据结构与算法--二叉树遍历(先序) 先序遍历先访问根节点, 然后以同样方式访问左子树和右子树 代码如下: /* *二叉树中,相对较小的值保存在左节点上,较大的值保存在右节点中 * ...

  6. javascript数据结构与算法--二叉树遍历(中序)

    javascript数据结构与算法--二叉树遍历(中序) 中序遍历按照节点上的键值,以升序访问BST上的所有节点 代码如下: /* *二叉树中,相对较小的值保存在左节点上,较大的值保存在右节点中 * ...

  7. 算法随笔-二叉树遍历的N种姿势

    最近在练习用Python刷算法,leetcode上刷了快300题.一开始怀疑自己根本不会写代码,现在觉得会写一点点了,痛苦又充实的刷题历程.对我这种半路出家的人而言,收获真的很大. 今天就从二叉树遍历 ...

  8. 《数据结构与算法(C语言版)》严蔚敏 | 第五章 建立二叉树,并完成三/四种遍历算法

    PS:所有的代码示例使用的都是这个图 2019-10-29 利用p126的算法5.3建立二叉树,并完成三种遍历算法 中序 后序 先序 #include<iostream> #include ...

  9. Python -二叉树 创建与遍历算法(很详细)

    树表示由边连接的节点.它是一个非线性的数据结构.它具有以下特性. 一个节点被标记为根节点. 除根节点之外的每个节点都与一个父节点关联. 每个节点可以有一个arbiatry编号的chid节点. 我们使用 ...

随机推荐

  1. Python3之文本操作

    文件操作示例分析: 文件操作一般要经历三个步骤: 打开文件 操作文件 关闭文件 读取操作示例: >>>f = open('test.txt', 'r') # 打开文件test.txt ...

  2. 图论 竞赛图(tournament)学习笔记

    竞赛图(tournament)学习笔记 现在只是知道几个简单的性质... 竞赛图也叫有向完全图. 其实就是无向完全图的边有了方向. ​ 有一个很有趣的性质就是:一个tournament要么没有环,如果 ...

  3. C++11 template parameter deduction

    C++11 引入了右值引用的概念,由此在引出 an rvalue reference to a cv-unqualified template parameter. 在template functio ...

  4. Machine learning吴恩达第三周 Logistic Regression

    1. Sigmoid function function g = sigmoid(z) %SIGMOID Compute sigmoid function % g = SIGMOID(z) compu ...

  5. MYSQL ERROR 1049 (42000): Unknown database

    https://www.cnblogs.com/hedgehog105/p/10196566.html lower_case_table_names=2

  6. 基础篇:3.1)规范化:3d草绘

    本章目的:3d草绘不同于cad工程图,但也有自己的规范要求.草绘要多多练习. 1.建模草图绘制 草图是大多数 3D 模型的基础.通常,创建模型的第一步是绘制草图,随后可以从草图生成特征.将一个或多个特 ...

  7. iis上部署本地数据库LocalDB的方法

    1. iis应用程序池的标识设置为"ApplicationPoolIdentify"(比较安全) 2. 不要将数据库物理文件保存在网站的物理路径内,因为iis应用程序池的标识为Ap ...

  8. sqlserver 并发机制

    一.事务四大属性 分别是原子性.一致性.隔离性.持久性. 1.原子性(Atomicity) 原子性是指事务包含的所有操作要么全部成功,要么全部失败回滚,因此事务的操作如果成功就必须要完全应用到数据库, ...

  9. win10安装ubuntu子系统配置

    # 更改apt源 cat > /etc/apt/sources.list <<'END' #阿里云 deb http://mirrors.aliyun.com/ubuntu/ tru ...

  10. zabbix4.2 安装

    官网https://www.zabbix.com/cn/download a. 安装 数据库rpm -Uvh https://repo.zabbix.com/zabbix/4.2/rhel/7/x86 ...