久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

PHP基于非遞歸算法實現先序、中序及后序遍歷二叉樹操作示例

這篇文章主要介紹了PHP基于非遞歸算法實現先序、中序及后序遍歷二叉樹操作,結合實例形式分析了php采用非遞歸算法對二叉樹進行先序、中序及后序遍歷操作的原理與具體實現技巧,需要

本文實例講述了PHP基于非遞歸算法實現先序、中序及后序遍歷二叉樹操作。分享給大家供大家參考,具體如下:

概述:

二叉樹遍歷原理如下:

PHP基于非遞歸算法實現先序、中序及后序遍歷二叉樹操作示例

針對上圖所示二叉樹遍歷:

1. 前序遍歷:先遍歷根結點,然后遍歷左子樹,最后遍歷右子樹。

ABDHECFG

2.中序遍歷:先遍歷左子樹,然后遍歷根結點,最后遍歷右子樹。

HDBEAFCG

3.后序遍歷:先遍歷左子樹,然后遍歷右子樹,最后遍歷根節點。

HDEBFGCA

實現方法:

先序遍歷:利用棧先進后出的特性,先訪問根節點,再把右子樹壓入,再壓入左子樹。這樣取出的時候是先取出左子樹,最后取出右子樹。

function preorder($root){
 $stack = array();
 array_push($stack, $root);
 while(!empty($stack)){
  $center_node = array_pop($stack);
  echo $center_node->value; // 根節點
  if($center_node->right != null)
   array_push($stack, $center_node->right); // 壓入右子樹
  if($center_node->left != null)
   array_push($stack, $center_node->left); // 壓入左子樹
 }
}

中序:需要從下向上遍歷,所以先把左子樹壓入棧,然后逐個訪問根節點和右子樹。

function inorder($root){
 $stack = array();
 $center_node = $root;
 while(!empty($stack) || $center_node != null){
  while($center_node != null){
   array_push($stack, $center_node);
   $center_node = $center_node->left;
  }
  $center_node = array_pop($stack);
  echo $center_node->value;
  $center_node = $center_node->right;
 }
}

后序:先把根節點存起來,然后依次儲存左子樹和右子樹。然后輸出。

function tailorder($root){
 $stack = array();
 $outstack = array();
 array_push($$stack, $root);
 while($empty($stack)){
  $center_node = array_pop($stack);
  array_push($outstack, $center_node);
  if($center_node->right != null)
   array_push($stack, $center_node->right);
  if($center_node->left != null)
   array_push($stack, $center_node->left);
 }
 while($empty($outstack)){
  $center_node = array_pop($outstack);
  echo $center_node->value;
 }
}

更多關于PHP相關內容感興趣的讀者可查看本站專題:《PHP數據結構與算法教程》、《php程序設計算法總結》、《php字符串(string)用法總結》、《PHP數組(Array)操作技巧大全》、《PHP常用遍歷算法與技巧總結》及《PHP數學運算技巧總結》

希望本文所述對大家PHP程序設計有所幫助。

您可能感興趣的文章:

  • PHP實現二叉樹的深度優先與廣度優先遍歷方法
  • php FLEA中二叉樹數組的遍歷輸出
  • PHP實現的線索二叉樹及二叉樹遍歷方法詳解
  • PHP Class&Object -- 解析PHP實現二叉樹
  • php實現的二叉樹遍歷算法示例
  • PHP構造二叉樹算法示例
  • PHP Class&Object -- PHP 自排序二叉樹的深入解析
  • PHP實現繪制二叉樹圖形顯示功能詳解【包括二叉搜索樹、平衡樹及紅黑樹】
  • PHP完全二叉樹定義與實現方法示例
  • PHP實現判斷二叉樹是否對稱的方法
  • PHP實現按之字形順序打印二叉樹的方法
【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。

相關文檔推薦

這篇文章主要介紹了PHP有序表查找之插值查找算法,簡單分析了插值查找算法的概念、原理并結合實例形式分析了php實現針對有序表插值查找的相關操作技巧,需要的朋友可以參考下
下面小編就為大家分享一篇ThinkPHP整合datatables實現服務端分頁的示例代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
下面小編就為大家分享一篇PHP實現APP微信支付的實例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
這篇文章主要介紹了PHP實現的多維數組排序算法,結合實例形式對比分析了php針對多維數組及帶有鍵名的多維數組進行排序相關操作技巧與注意事項,需要的朋友可以參考下
這篇文章主要為大家詳細介紹了php結合ajaxuploadfile實現無刷新文件上傳功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本篇文章給大家詳細介紹了PHP開發接口使用RSA進行加密解密方法,對此有興趣的朋友可以學習下。
主站蜘蛛池模板: 91社区视频| 天天干天天玩天天操 | 色综合99 | 亚洲一区二区在线电影 | a在线观看免费 | 亚洲高清视频一区二区 | 亚洲免费影院 | 91精品国产一区二区三区 | 国产精久久久久久久 | 蜜桃视频一区二区三区 | 成人国产在线观看 | 国产第1页 | 91精品国产91久久久久久最新 | 伊人网影院| 国产电影一区 | 日韩成人在线观看 | 在线观看免费av网 | 日韩视频―中文字幕 | 国产成人精品久久二区二区 | 亚洲成人免费视频在线观看 | 91精品国产欧美一区二区 | 久久国产综合 | 亚洲精品久久久久久一区二区 | 中文字幕av一区 | www.五月婷婷.com | 亚洲伊人精品酒店 | 日韩精品亚洲专区在线观看 | 日本一区二区三区在线观看 | 日韩有码一区 | 日韩国产中文字幕 | 亚洲91精品| 精品一区二区在线视频 | 精品久久中文字幕 | 久久久国产一区二区三区 | 亚洲综合三区 | 99在线免费视频 | 久久综合色综合 | 成人在线小视频 | 成人一区二区在线 | 午夜综合 | 中文字幕亚洲欧美日韩在线不卡 |