php之二叉树,php 二叉树

/**

* 然后采用先序遍历、中序遍历、后序遍历的方式来访问并打印出节点的数据。

* */

/*

树节点信息

*/

class Node1 {

public $value;   //节点的数据

public $leftChild;    //指向左孩子

public $rightChild;    //指向右孩子

function __construct($value) {

$this->value = $value;

$this->leftChild = null;

$this->rightChild = null;

}

}

//没有跟好的建造树的方法,用土办法

$A = new Node1("A");

$B = new Node1("B");

$C = new Node1("C");

$D = new Node1("D");

$E = new Node1("E");

$F = new Node1("F");

$G = new Node1("G");

$A->leftChild = $B;

$A->rightChild = $C;

$B->leftChild = $D;

$B->rightChild = $E;

$E->rightChild = $G;

$C->leftChild = $F;

print_r($A);

class Tree

{

var $traverse;

/**

* 前序遍历:访问根结点,遍历左子树,遍历右子树

*@param obj $tree

*/

public function preOrder($tree)

{

$this->traverse .= " ".$tree->value;        //根节点的值

if (! is_null($tree->leftChild)) {

$this->preOrder($tree->leftChild);     //左子树 前序遍历

}

if (! is_null($tree->rightChild)) {

$this->preOrder($tree->rightChild);  //右子树 前序遍历

}

}

/**

* 中序遍历:遍历左子树,访问根结点,遍历右子树

*@param obj $tree     //左 --》 根 --》右

*/

public function inOrder($tree)

{

if (! is_null($tree->leftChild)) {

$this->inOrder($tree->leftChild);

}

$this->traverse .= " ".$tree->value;

if (! is_null($tree->rightChild)) {

$this->inOrder($tree->rightChild);

}

}

/**

* 后序遍历:遍历左子树,遍历右子树,遍历右子树

*@param obj $tree

*/

public function postOrder($tree)

{

if (! is_null($tree->leftChild)) {

$this->postOrder($tree->leftChild);

}

if (! is_null($tree->rightChild)) {

$this->postOrder($tree->rightChild);

}

$this->traverse .= " ".$tree->value;

}

/** 前 根 -》左 -》右

*  中 左 -》根 -》右

*  后 左 -》右 -》根    中s -> 前e -> 前s

* 已知前序、中序遍历,求后序遍历

*已知前序、中序遍历,求后序遍历

*思路:先确定根,根据中序列确定左子树,确定右子树,

*2在左子树中同上递归

*3在右子树中同上递归

*4.打印当前根

* @param string $inorder    中

* @param string $preorder   前

*/

function getPostByinpre($inorder,$preorder)

{

if (strlen($preorder)<=0) {

return ;

}elseif (strlen($preorder)==1)

{

$this->traverse .=" ". $preorder;

return ;

}

//第一个元素师根节点位置

$k = strpos($inorder,$preorder[0]);  //左子树个数

$temp_preorder = substr($preorder,1,$k);  //左子树

$temp_inorder = substr($inorder,0,$k);    //左子树  DBEG BDEG

$this->getPostByinpre($temp_inorder,$temp_preorder);

//中s -> 前e -> 前s

$preorder_temp = substr($preorder,$k+1,strlen($preorder)-$k-1);  //右子树   FC

$inorder_temp = substr($inorder,$k+1,strlen($inorder)-$k-1);   //右子树     FC

$this->getPostByinpre($inorder_temp,$preorder_temp);

//后续遍历输出节点

$this->traverse .=" ".  $preorder[0];

}

}

$tree = new Tree();

$tree->preOrder($A);

echo "".$tree->traverse;

$tree->traverse = "";

$tree->inOrder($A);

echo "".$tree->traverse;

$tree->traverse = "";

$tree->postOrder($A);

echo "".$tree->traverse;

echo "";

unset($tree);

$tree = new Tree();   //   k        1

$tree ->getPostByinpre("DBEGAFC ","ABDEGCF");

echo $tree->traverse;

?>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值