PHP根据树的前序遍历和中序遍历构造树并输出后序遍历的方法

来源:爱站网时间:2020-06-01编辑:网友分享
中间阶遍历和前序或后序可以唯一地确定二叉树,在给定前序遍历和中间序遍历序列的情况下,我们可以确定建立此二叉树,然后后序遍历就可以得到相应的序列,下面是爱站技术频道小编为大家带来的PHP根据树的前序遍历和中序遍历构造树并输出后序遍历的方法吧!

中间阶遍历和前序或后序可以唯一地确定二叉树,在给定前序遍历和中间序遍历序列的情况下,我们可以确定建立此二叉树,然后后序遍历就可以得到相应的序列,下面是爱站技术频道小编为大家带来的PHP根据树的前序遍历和中序遍历构造树并输出后序遍历的方法吧!

先来看看前序遍历、中序遍历与后序遍历原理图:

根据树的前序遍历和中序遍历构造树并输出后序遍历代码如下:

m_value=$preorder[0];
  if(count($preorder)==1){
    $headNode->m_left=null;
    $headNode->m_right=null;
    return $headNode;
  }
  array_shift($preorder);
  $pos=array_search($headNode->m_value,$inorder);
  $leftin=array_slice($inorder,0,$pos);
  $rightin=array_slice($inorder,$pos+1);
  $leftpre=array_slice($preorder,0,$pos);
  $rightpre=array_slice($preorder,$pos);
  $headNode->m_left=ConstructCore($leftpre,$leftin);
  $headNode->m_right=ConstructCore($rightpre,$rightin);
  return $headNode;
}
$pre=array(1,2,4,7,3,5,6,8);
$in=array(4,7,2,1,5,3,8,6);
$tree=ConstructCore($pre,$in);
function tail($tree){
  if($tree->m_right!=null)
  echo tail($tree->m_right);
  if($tree->m_left!=null)
  echo tail($tree->m_left);
    echo $tree->m_value;
}
tail($tree);
?>

运行结果:

86537421

上述就是爱站技术频道小编带给大家的PHP根据树的前序遍历和中序遍历构造树并输出后序遍历的方法,其实程序员并不是万能的,而我们自学更改源代码很麻烦,一定要找一个靠谱的平台。

上一篇:php实现的中秋博饼游戏之掷骰子并输出结果功能详解

下一篇:php摘要生成函数的介绍

您可能感兴趣的文章

相关阅读

热门软件源码

最新软件源码下载