婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > PHP實(shí)現(xiàn)二叉樹深度優(yōu)先遍歷(前序、中序、后序)和廣度優(yōu)先遍歷(層次)實(shí)例詳解

PHP實(shí)現(xiàn)二叉樹深度優(yōu)先遍歷(前序、中序、后序)和廣度優(yōu)先遍歷(層次)實(shí)例詳解

熱門標(biāo)簽:遼寧ai電銷機(jī)器人價(jià)格 地圖標(biāo)注專員怎么樣 長沙做地圖標(biāo)注公司 房產(chǎn)中介用的是什么外呼系統(tǒng) 福建銀行智能外呼系統(tǒng)價(jià)格 四川保險(xiǎn)智能外呼系統(tǒng)供應(yīng)商 寧波外呼營銷系統(tǒng) 電話機(jī)器人銷售主要負(fù)責(zé)什么 上海做外呼線路的通信公司

本文實(shí)例講述了PHP實(shí)現(xiàn)二叉樹深度優(yōu)先遍歷(前序、中序、后序)和廣度優(yōu)先遍歷(層次)。分享給大家供大家參考,具體如下:

前言:

深度優(yōu)先遍歷:對每一個(gè)可能的分支路徑深入到不能再深入為止,而且每個(gè)結(jié)點(diǎn)只能訪問一次。要特別注意的是,二叉樹的深度優(yōu)先遍歷比較特殊,可以細(xì)分為先序遍歷、中序遍歷、后序遍歷。具體說明如下:

前序遍歷:根節(jié)點(diǎn)->左子樹->右子樹
中序遍歷:左子樹->根節(jié)點(diǎn)->右子樹
后序遍歷:左子樹->右子樹->根節(jié)點(diǎn)

廣度優(yōu)先遍歷:又叫層次遍歷,從上往下對每一層依次訪問,在每一層中,從左往右(也可以從右往左)訪問結(jié)點(diǎn),訪問完一層就進(jìn)入下一層,直到?jīng)]有結(jié)點(diǎn)可以訪問為止。

例如對于一下這棵樹:

深度優(yōu)先遍歷:

前序遍歷:10 8 7 9 12 11 13
中序遍歷:7 8 9 10 11 12 13
后序遍歷:7 9 8 11 13 12 10

廣度優(yōu)先遍歷:

層次遍歷:10 8 12 7 9 11 13

二叉樹的深度優(yōu)先遍歷的非遞歸的通用做法是采用棧,廣度優(yōu)先遍歷的非遞歸的通用做法是采用隊(duì)列。

深度優(yōu)先遍歷:

1、前序遍歷:

/**
* 前序遍歷(遞歸方法)
*/
private function pre_order1($root)
{
    if (!is_null($root)) {
      //這里用到常量__FUNCTION__,獲取當(dāng)前函數(shù)名,好處是假如修改函數(shù)名的時(shí)候,里面的實(shí)現(xiàn)不用修改
      $function = __FUNCTION__;
      echo $root->key . " ";
      $this->$function($root->left);
      $this->$function($root->right);
    }
}
/**
* 前序遍歷(非遞歸方法)
* 因?yàn)楫?dāng)遍歷過根節(jié)點(diǎn)之后還要回來,所以必須將其存起來??紤]到后進(jìn)先出的特點(diǎn),選用棧存儲。
*/
private function pre_order2($root)
{
    //    $stack = new splstack();
    //    $stack->push($root);
    //    while(!$stack->isEmpty()){
    //      $node = $stack->pop();
    //      echo $node->key.' ';
    //      if(!is_null($node->right)){
    //        $stack->push($node->right);
    //      }
    //      if(!is_null($node->left)){
    //        $stack->push($node->left);
    //      }
    //    }
    if (is_null($root)) {
      return;
    }
    $stack = new splstack();
    $node = $root;
    while (!is_null($node) || !$stack->isEmpty()) {
      while (!is_null($node)) {
        //只要結(jié)點(diǎn)不為空就應(yīng)該入棧保存,與其左右結(jié)點(diǎn)無關(guān)
        $stack->push($node);
        echo $node->key . ' ';
        $node = $node->left;
      }
      $node = $stack->pop();
      $node = $node->right;
    }
}
//前序遍歷
public function PreOrder()
{
    // 所在對象中的tree屬性保存了一個(gè)樹的引用
    //   $this->pre_order1($this->tree->root);
    $this->pre_order2($this->tree->root);
}

說明:1、我將所有的遍歷方法都封裝在一個(gè)類 traverse 里面了。2、pre_order2方法中,在使用棧的過程中,我使用的是PHP標(biāo)準(zhǔn)庫SPL提供的splstack,如果你們習(xí)慣使用數(shù)組的話,可以使用 array_push() array_pop() 模擬實(shí)現(xiàn)。

2、中序遍歷:

/**
* 中序遍歷(遞歸方法)
*/
private function mid_order1($root)
{
    if (!is_null($root)) {
      $function = __FUNCTION__;
      $this->$function($root->left);
      echo $root->key . " ";
      $this->$function($root->right);
    }
}
/**
* 中序遍歷(非遞歸方法)
* 因?yàn)楫?dāng)遍歷過根節(jié)點(diǎn)之后還要回來,所以必須將其存起來。考慮到后進(jìn)先出的特點(diǎn),選用棧存儲。
*/
private function mid_order2($root)
{
    if (is_null($root)) {
      return;
    }
    $stack = new splstack();
    $node = $root;
    while (!is_null($node) || !$stack->isEmpty()) {
      while (!is_null($node)) {
        $stack->push($node);
        $node = $node->left;
      }
      $node = $stack->pop();
      echo $node->key . ' ';
      $node = $node->right;
    }
}
//中序遍歷
public function MidOrder()
{
    //    $this->mid_order1($this->tree->root);
    $this->mid_order2($this->tree->root);
}

3、后序遍歷:

/**
* 后序遍歷(遞歸方法)
*/
private function post_order1($root)
{
    if (!is_null($root)) {
      $function = __FUNCTION__;
      $this->$function($root->left);
      $this->$function($root->right);
      echo $root->key . " ";
    }
}
/**
* 后序遍歷(非遞歸方法)
* 因?yàn)楫?dāng)遍歷過根節(jié)點(diǎn)之后還要回來,所以必須將其存起來??紤]到后進(jìn)先出的特點(diǎn),選用棧存儲。
* 由于在訪問了左子節(jié)點(diǎn)后怎么跳到右子節(jié)點(diǎn)是難點(diǎn),這里使用一個(gè)標(biāo)識lastVisited來標(biāo)識上一次訪問的結(jié)點(diǎn)
*/
private function post_order2($root)
{
    if (is_null($root)) {
      return;
    }
    $node = $root;
    $stack = new splstack();
    //保存上一次訪問的結(jié)點(diǎn)引用
    $lastVisited = NULL;
    $stack->push($node);
    while(!$stack->isEmpty()){
      $node = $stack->top();//獲取棧頂元素但不彈出
      if(($node->left == NULL  $node->right == NULL) || ($node->right == NULL  $lastVisited == $node->left) || ($lastVisited == $node->right)){
        echo $node->key.' ';
        $lastVisited = $node;
        $stack->pop();
      }else{
        if($node->right){
          $stack->push($node->right);
        }
        if($node->left){
          $stack->push($node->left);
        }
      }
    }
}
//后序遍歷
public function PostOrder()
{
    //    $this->post_order1($this->tree->root);
    $this->post_order2($this->tree->root);
}

廣度優(yōu)先遍歷:

1、層次遍歷:

/**
* 層次遍歷(遞歸方法)
* 由于是按層逐層遍歷,因此傳遞樹的層數(shù)
*/
private function level_order1($root,$level){
    if($root == NULL || $level  1){
      return;
    }
    if($level == 1){
      echo $root->key.' ';
      return;
    }
    if(!is_null($root->left)){
      $this->level_order1($root->left,$level - 1);
    }
    if(!is_null($root->right)){
      $this->level_order1($root->right,$level - 1);
    }
}
/**
* 層次遍歷(非遞歸方法)
* 每一層從左向右輸出
元素需要儲存有先進(jìn)先出的特性,所以選用隊(duì)列存儲。
*/
private function level_order2($root){
    if(is_null($root)){
      return;
    }
    $node = $root;
    //利用隊(duì)列實(shí)現(xiàn)
//    $queue = array();
//    array_push($queue,$node);
//
//    while(!is_null($node = array_shift($queue))){
//      echo $node->key.' ';
//      if(!is_null($node->left)){
//        array_push($queue,$node->left);
//      }
//      if(!is_null($node->right)){
//        array_push($queue,$node->right);
//      }
//    }
    $queue = new splqueue();
    $queue->enqueue($node);
    while(!$queue->isEmpty()){
      $node = $queue->dequeue();
      echo $node->key.' ';
      if (!is_null($node->left)) {
        $queue->enqueue($node->left);
      }
      if (!is_null($node->right)) {
        $queue->enqueue($node->right);
      }
    }
}
//層次遍歷
public function LevelOrder(){
//    $level = $this->getdepth($this->tree->root);
//    for($i = 1;$i = $level;$i ++){
//      $this->level_order1($this->tree->root,$i);
//    }
    $this->level_order2($this->tree->root);
}
//獲取樹的層數(shù)
private function getdepth($root){
    if(is_null($root)){
      return 0;
    }
    $left = getdepth($root -> left);
    $right = getdepth($root -> right);
    $depth = ($left > $right ? $left : $right) + 1;
    return $depth;
}

說明:level_order2方法中,在使用隊(duì)列的過程中,我使用的是PHP標(biāo)準(zhǔn)庫SPL提供的splqueue,如果你們習(xí)慣使用數(shù)組的話,可以使用 array_push() array_shift() 模擬實(shí)現(xiàn)。

使用:

現(xiàn)在我們來看看客戶端代碼:

class Client
{
  public static function Main()
  {
    try {
      //實(shí)現(xiàn)文件的自動加載
      function autoload($class)
      {
        include strtolower($class) . '.php';
      }
      spl_autoload_register('autoload');
      $arr = array(10, 8, 12, 7, 9, 11, 13);
      $tree = new Bst();
//      $tree = new Avl();
//      $tree = new Rbt();
      $tree->init($arr);
      $traverse = new traverse($tree);
      $traverse->PreOrder();
//      $traverse->MidOrder();
//      $traverse->PostOrder();
//      $traverse->LevelOrder();
    } catch (Exception $e) {
      echo $e->getMessage();
    }
  }
}
CLient::Main();

補(bǔ)充:

1. 在客戶端中所使用的三個(gè)類 Bst、Avl、Rbt 大家可以參考前面一篇:《PHP實(shí)現(xiàn)繪制二叉樹圖形顯示功能詳解》

2. 為什么我推薦大家使用SPL標(biāo)準(zhǔn)庫中提供的splstacksplqueue呢?這是我在某一篇文章中看到的:雖然我們可以使用傳統(tǒng)的變量類型來描述數(shù)據(jù)結(jié)構(gòu),例如用數(shù)組來描述堆棧(Strack)– 然后使用對應(yīng)的方式 pop 和 push(array_pop()、array_push()),但你得時(shí)刻小心,因?yàn)楫吘顾鼈儾皇菍iT用于描述數(shù)據(jù)結(jié)構(gòu)的 – 一次誤操作就有可能破壞該堆棧。而 SPL 的 SplStack 對象則嚴(yán)格以堆棧的形式描述數(shù)據(jù),并提供對應(yīng)的方法。同時(shí),這樣的代碼應(yīng)該也能理解它在操作堆棧而非某個(gè)數(shù)組,從而能讓你的同伴更好的理解相應(yīng)的代碼,并且它更快。原文地址:PHP SPL,遺落的寶石

3. 本文相關(guān)參考文章: 《C語言二叉樹常見操作詳解【前序,中序,后序,層次遍歷及非遞歸查找,統(tǒng)計(jì)個(gè)數(shù),比較,求深度】》、《Java實(shí)現(xiàn)二叉樹的深度優(yōu)先遍歷和廣度優(yōu)先遍歷算法示例》

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計(jì)算法總結(jié)》、《php字符串(string)用法總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《PHP常用遍歷算法與技巧總結(jié)》及《PHP數(shù)學(xué)運(yùn)算技巧總結(jié)》

希望本文所述對大家PHP程序設(shè)計(jì)有所幫助。

您可能感興趣的文章:
  • PHP排序二叉樹基本功能實(shí)現(xiàn)方法示例
  • PHP實(shí)現(xiàn)從上往下打印二叉樹的方法
  • PHP獲取二叉樹鏡像的方法
  • PHP實(shí)現(xiàn)按之字形順序打印二叉樹的方法
  • PHP基于非遞歸算法實(shí)現(xiàn)先序、中序及后序遍歷二叉樹操作示例
  • PHP實(shí)現(xiàn)判斷二叉樹是否對稱的方法
  • PHP實(shí)現(xiàn)繪制二叉樹圖形顯示功能詳解【包括二叉搜索樹、平衡樹及紅黑樹】
  • PHP完全二叉樹定義與實(shí)現(xiàn)方法示例
  • php實(shí)現(xiàn)二叉樹中和為某一值的路徑方法

標(biāo)簽:佛山 延安 工商登記 澳門 宜春 常德 宿遷 深圳

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP實(shí)現(xiàn)二叉樹深度優(yōu)先遍歷(前序、中序、后序)和廣度優(yōu)先遍歷(層次)實(shí)例詳解》,本文關(guān)鍵詞  PHP,實(shí)現(xiàn),二叉,樹,深度,優(yōu)先,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PHP實(shí)現(xiàn)二叉樹深度優(yōu)先遍歷(前序、中序、后序)和廣度優(yōu)先遍歷(層次)實(shí)例詳解》相關(guān)的同類信息!
  • 本頁收集關(guān)于PHP實(shí)現(xiàn)二叉樹深度優(yōu)先遍歷(前序、中序、后序)和廣度優(yōu)先遍歷(層次)實(shí)例詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲人成小说网站色在线 | 91麻豆精品91久久久久同性| 午夜亚洲国产au精品一区二区| 精品国产免费久久| 欧美不卡一区二区三区四区| 制服视频三区第一页精品| 91国产福利在线| 91国产成人在线| 色综合中文综合网| 自拍偷拍亚洲欧美日韩| 1000精品久久久久久久久| 国产精品久久久久久久裸模| 国产精品国产成人国产三级| 亚洲欧洲日韩女同| 亚洲免费伊人电影| 日韩av电影免费观看高清完整版 | 亚洲欧美日韩国产综合在线 | 久久先锋影音av鲁色资源| 久久一区二区视频| 久久久综合九色合综国产精品| 国产欧美一区二区三区网站| 自拍偷拍亚洲综合| 日韩高清欧美激情| 国产传媒久久文化传媒| 色www精品视频在线观看| 蜜臀av一区二区在线观看| 国产一区视频网站| 亚洲日本在线看| 日韩成人精品视频| 一本色道久久综合亚洲aⅴ蜜桃| 一本色道久久综合亚洲91| 欧美精品一区二区三| 亚洲精品国产精华液| 国产成人av影院| 日韩精品一区二区三区视频播放| 国产精品久久久久一区二区三区| 日韩黄色一级片| 欧美日韩免费在线视频| 日韩毛片一二三区| 成人av在线网| 中文字幕亚洲精品在线观看| 免费在线观看成人| 欧美精品在线观看一区二区| 亚洲黄一区二区三区| 成人免费高清视频在线观看| 精品999在线播放| 国产精品自拍在线| 中文字幕av免费专区久久| 精品一区二区在线观看| 欧美一区二区三区免费视频| 日韩精品五月天| 精品久久久久香蕉网| 国产一区不卡精品| 国产精品久久久久久久岛一牛影视 | 亚洲自拍偷拍麻豆| 在线亚洲一区观看| 久色婷婷小香蕉久久| 亚洲国产电影在线观看| 欧美三级电影在线观看| 久久国产精品无码网站| 中文字幕不卡一区| 日韩一区二区在线免费观看| 国产精品综合二区| 六月丁香综合在线视频| 国产精品拍天天在线| 91精品国产色综合久久ai换脸 | 亚洲欧美一区二区三区久本道91| 欧美日韩一级片在线观看| 国内精品第一页| 亚洲国产精品久久久久秋霞影院 | 成人高清免费在线播放| 日本怡春院一区二区| 欧美国产日本视频| 欧美丰满美乳xxx高潮www| 风间由美性色一区二区三区| 亚洲va中文字幕| **性色生活片久久毛片| 久久久精品免费观看| 欧美日韩大陆在线| 欧美亚日韩国产aⅴ精品中极品| 国产一区激情在线| 青青草原综合久久大伊人精品| 中文字幕人成不卡一区| 欧美国产精品中文字幕| 精品少妇一区二区三区视频免付费 | 91在线视频播放地址| 捆绑调教一区二区三区| 日本视频一区二区| 久久激情五月激情| 看电视剧不卡顿的网站| 久久精品av麻豆的观看方式| 青青青伊人色综合久久| 久久精品国产亚洲一区二区三区| 喷水一区二区三区| 国产一区二区三区av电影| 极品少妇一区二区三区精品视频| 蜜臀av性久久久久蜜臀aⅴ流畅 | 美女视频一区二区| 国产一区二区免费视频| 高清免费成人av| 欧美日韩视频专区在线播放| 欧美国产丝袜视频| 午夜精品久久久久久久久| 欧美伊人精品成人久久综合97| 久久婷婷色综合| 国产清纯白嫩初高生在线观看91| 欧美成人精品二区三区99精品| 69久久夜色精品国产69蝌蚪网| 精品国产一区二区三区四区四| 国产女人aaa级久久久级| 视频一区二区国产| 99re热这里只有精品视频| 精品国产乱码久久久久久久| 亚洲乱码日产精品bd| 国产成人午夜精品5599| 欧美久久一二区| 亚洲福利视频一区| 91福利在线导航| 亚洲免费电影在线| 色综合久久久久综合| 国产精品久久久爽爽爽麻豆色哟哟| 老司机午夜精品| 欧美一区二区久久久| 亚洲五月六月丁香激情| 色就色 综合激情| 国产精品久久久久久久久动漫| 国产999精品久久久久久绿帽| 日韩三级中文字幕| 日韩av在线发布| 精品国产一区二区三区久久久蜜月| 亚洲专区一二三| 欧美亚洲禁片免费| 天堂久久一区二区三区| 欧美人牲a欧美精品| 亚洲成人自拍一区| 欧美电视剧在线看免费| 狠狠色丁香婷综合久久| 国产偷国产偷亚洲高清人白洁| 国产一区日韩二区欧美三区| 国产欧美精品日韩区二区麻豆天美| 国产伦精品一区二区三区免费迷| 精品国产百合女同互慰| 成人黄色小视频| 免费一级片91| 亚洲视频在线观看一区| 日本丶国产丶欧美色综合| 日韩黄色在线观看| 国产精品伦一区| 51久久夜色精品国产麻豆| 成人网在线免费视频| 日本午夜精品一区二区三区电影 | 亚洲精品日韩专区silk| 欧美肥妇free| 91首页免费视频| 国内精品国产成人| 无码av免费一区二区三区试看 | 成人av免费在线| 国内精品视频一区二区三区八戒| 亚洲一区二区视频在线| 国产日韩三级在线| 日韩免费性生活视频播放| 欧美性videosxxxxx| 一本一道久久a久久精品 | 国产精品人妖ts系列视频| 日韩精品自拍偷拍| 精品国产一区二区三区不卡| 日韩欧美国产电影| 久久综合999| 中文字幕一区二区三区在线观看 | 蜜桃一区二区三区四区| 亚洲人成网站在线| 亚洲一区二区三区四区不卡| 亚洲一二三级电影| 亚洲国产精品久久人人爱| 亚洲va国产天堂va久久en| 午夜免费久久看| 免费观看日韩电影| 国产毛片精品国产一区二区三区| 东方aⅴ免费观看久久av| 91麻豆免费观看| 在线精品视频一区二区三四 | 欧美日韩免费一区二区三区视频| 欧美视频三区在线播放| 精品女同一区二区| 亚洲视频每日更新| 午夜国产精品影院在线观看| 国产一区二区三区在线观看精品 | 国产98色在线|日韩| 精品视频在线视频| 欧美国产综合一区二区| 日韩中文字幕1| 91久久线看在观草草青青| 精品国产污污免费网站入口| 国产精品毛片a∨一区二区三区| 香蕉乱码成人久久天堂爱免费| 国产精品1024| 精品日产卡一卡二卡麻豆| 亚洲成a人在线观看| 91久久精品国产91性色tv| 一区二区三区欧美|