91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》
  • 首頁 > 
  • 教程 > 
  • 開發技術 > 
  • PHP如何根據樹的前序遍歷和中序遍歷構造樹并輸出后序遍歷

PHP如何根據樹的前序遍歷和中序遍歷構造樹并輸出后序遍歷

發布時間:2021-07-24 14:45:47 來源:億速云 閱讀:180 作者:小新 欄目:開發技術

這篇文章將為大家詳細講解有關PHP如何根據樹的前序遍歷和中序遍歷構造樹并輸出后序遍歷,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

具體如下:

先來看看前序遍歷、中序遍歷與后序遍歷原理圖:

PHP如何根據樹的前序遍歷和中序遍歷構造樹并輸出后序遍歷

根據樹的前序遍歷和中序遍歷構造樹并輸出后序遍歷代碼如下:

<?php
class BinaryTreeNode{
  public $m_value;
  public $m_left;
  public $m_right;
}
function ConstructCore($preorder,$inorder){
  if(count($preorder)!=count($inorder) || count($preorder)==0 || count($inorder)==0)
  return null;
  $headNode=new BinaryTreeNode;
  $headNode->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如何根據樹的前序遍歷和中序遍歷構造樹并輸出后序遍歷”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

php
AI

凯里市| 临湘市| 乌兰察布市| 堆龙德庆县| 海伦市| 聂拉木县| 双峰县| 获嘉县| 改则县| 华安县| 清镇市| 宝坻区| 大名县| 黑河市| 习水县| 达日县| 夏河县| 江都市| 大洼县| 崇明县| 垣曲县| 黄山市| 鄂伦春自治旗| 榕江县| 府谷县| 荔波县| 贵港市| 蚌埠市| 斗六市| 剑河县| 徐州市| 新巴尔虎左旗| 张家港市| 喀喇| 汝城县| 手机| 沅江市| 芷江| 高淳县| 大荔县| 延寿县|