PHP构造二叉树算法示例

 更新时间:2017年06月21日 10:58:31   作者:火蜥蜴  
本篇文章主要介绍了PHP构造二叉树算法示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

树(Tree)在数据结构还是很重要的,这里表示二叉树用括号表示法表示。先写一个二叉树节点类:

// 二叉树节点
class BTNode {
  public $data;

  public $lchild = NULL;

  public $rchild = NULL;

  public function __construct($data) {
    $this->data = $data;
  }
}

然后构造二叉树:

function CreateBTNode(&$root,string $str)
{
  $strArr = str_split($str);
  $stack = [];
  $p = NULL; // 指针
  $top = -1;
  $k = $j = 0;
  $root = NULL;
  foreach ($strArr as $ch) {
    switch ($ch) {
      case '(':
        $top++;
        array_push($stack, $p);
        $k = 1;
        break;
      case ')':
        array_pop($stack);
        break;
      case ',':
        $k = 2;
        break;
      default:
        $p = new BTNode($ch);
        if($root == NULL) {
          $root = $p;
        } else {
          switch ($k) {
            case 1:
              end($stack)->lchild = $p;
              break;
            case 2:
              end($stack)->rchild = $p;
              break;
          }
        }
        break;
    }
  }
}

这里写上一个打印二叉树的函数(中序遍历):

function PrintBTNode($node)
{
  if($node != NULL) {
    PrintBTNode($node->lchild);
    echo $node->data;
    PrintBTNode($node->rchild);
  }
}

运行结果:

输入一个字符串
"A(B(C,D),G(F))"

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • php的declare控制符和ticks教程(附示例)

    php的declare控制符和ticks教程(附示例)

    declare是PHP的流程控制结构,directive目前支持两个指令,ticks的使用需配合register_tick_function函数使用,看下面的小示例吧
    2014-03-03
  • 解决laravel查询构造器中的别名问题

    解决laravel查询构造器中的别名问题

    今天小编就为大家分享一篇解决laravel查询构造器中的别名问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-10-10
  • 单点登录 Ucenter示例分析

    单点登录 Ucenter示例分析

    正如标题所言,需要了解下Ucenter登录步骤,之后在进行有效的分析,下面有个不错的示例,感兴趣的朋友可以参考下
    2013-10-10
  • php post json参数的传递和接收处理方法

    php post json参数的传递和接收处理方法

    今天小编就为大家分享一篇php post json参数的传递和接收处理方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-05-05
  • ThinkPHP框架设计及扩展详解

    ThinkPHP框架设计及扩展详解

    本文详细介绍了ThinkPHP框架的框架分层及url路由、ThinkPHP扩展、数据库驱动扩展、Behavior行为扩展以及源码分析与不足,讲解的十分全面系统,这里推荐给大家,有想学习ThinkPHP的小伙伴千万不要错过。
    2014-11-11
  • CodeIgniter框架钩子机制实现方法【hooks类】

    CodeIgniter框架钩子机制实现方法【hooks类】

    这篇文章主要介绍了CodeIgniter框架钩子机制实现方法,结合具体的hooks类文件描述了钩子机制的原理与相关操作技巧,需要的朋友可以参考下
    2018-08-08
  • joomla组件开发入门教程

    joomla组件开发入门教程

    这篇文章主要介绍了joomla组件开发的方法,结合实例形式分析了joomla组件的结构、功能与具体使用技巧,需要的朋友可以参考下
    2016-05-05
  • ThinkPHP 3.2.3实现加减乘除图片验证码

    ThinkPHP 3.2.3实现加减乘除图片验证码

    这篇文章主要为大家详细介绍了ThinkPHP 3.2.3实现加减乘除图片验证码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-12-12
  • php fckeditor 调用的函数

    php fckeditor 调用的函数

    showfck() 编辑器调用函数
    2009-06-06
  • thinkphp实现发送邮件密码找回功能实例

    thinkphp实现发送邮件密码找回功能实例

    这篇文章主要介绍了thinkphp实现发送邮件密码找回功能的方法,以实例形式详细讲述了配置文件与功能代码的实现方法,是非常实用的技巧,需要的朋友可以参考下
    2014-12-12

最新评论