今天使用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. 条目二十二《切勿修改set或multiset的键》

    条目二十二<切勿修改set或multiset的键> 所有的标准关联容器一样,set和multiset按照一定的顺序来存放自己的元素,而这些容器的正确行为也是建立在其元素保持有序的基础之上的 ...

  2. python高级(四)—— 文本和字节序列(编码问题)

    本文主要内容 字符 字节 结构体和内存视图 字符和字节之间的转换——编解码器 BOM鬼符  标准化Unicode字符串 Unicode文本排序 python高级——目录 文中代码均放在github上: ...

  3. USART列子

    #include "stm32f10x.h" void USART_INit(void) { GPIO_InitTypeDef GPIO_Initstructe; USART_In ...

  4. 洛谷 P3285 / loj 2212 [SCOI2014] 方伯伯的 OJ 题解【平衡树】【线段树】

    平衡树分裂钛好玩辣! 题目描述 方伯伯正在做他的 OJ.现在他在处理 OJ 上的用户排名问题. OJ 上注册了 \(n\) 个用户,编号为 \(1\sim n\),一开始他们按照编号排名.方伯伯会按照 ...

  5. 在win7系统设置SQL Server2014 express为远程数据

    如何设置远程访问到SQLserver服务器(局域网内的设置) 1.首先,使用Windows+R键 输入services.msc 打开本地服务. *说明:①MSSQLSERVER是正式使用的SQL创建实 ...

  6. cordova 更改app的图标

    写在前面:cordova 使一个前端开发者成为一个“假”的android开发人员,不得不说提供给我们巨大的方便~,cordova打包生成的apk的默认样式和启动的名字真的是需要我们字更改的:本文将记录 ...

  7. 3dsmax2013卸载/安装失败/如何彻底卸载清除干净3dsmax2013注册表和文件的方法

    3dsmax2013提示安装未完成,某些产品无法安装该怎样解决呢?一些朋友在win7或者win10系统下安装3dsmax2013失败提示3dsmax2013安装未完成,某些产品无法安装,也有时候想重新 ...

  8. 转 功能强大的shell:if条件语句

    原文 http://blog.zol.com.cn/2322/article_2321767.html 功能强大的shell:if条件语句 if语句测试条件,测试条件返回真(0)或假(1)后,可相应执 ...

  9. 兼容IE6-9,FF,Chrome的box-shadow效果(纯CSS)

    昨天由于工作关系,遇上了这个问题,苦恼一日无解——残念. 所幸终于在今天早上得到了解决,遗憾的是灵活性不够强,不能根据内容自适应,要配合JS才能达到自适应效果 不过总结到这里已经很满意了,毕竟规律已经 ...

  10. Visual Studio2017中如何让ADO.NET实体数据模型[EntityFramework]支持MariaDB&MySQL数据源

    近期由于工作需要,需要重新修改设计系统的ADO.NET实体数据模型.edmx文件中间,在完成实际中途遇到一些实际使用问题,特此记录. 1. Visual Studio 2017 无法以实体设计模式打开 ...