成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

使用javascript實(shí)現(xiàn)排序二叉樹(2)

susheng / 2429人閱讀

摘要:使用實(shí)現(xiàn)排序二叉樹上一篇文章我們構(gòu)造了基本的一個(gè)排序二叉樹的數(shù)據(jù)結(jié)構(gòu),但是僅僅是定義了一個(gè)方法去創(chuàng)建二叉排序樹,今天我們來(lái)給我們的數(shù)據(jù)結(jié)構(gòu)添加一些遍歷的功能。

使用javascript實(shí)現(xiàn)排序二叉樹(2)

上一篇文章我們構(gòu)造了基本的一個(gè)排序二叉樹的數(shù)據(jù)結(jié)構(gòu),但是僅僅是定義了一個(gè)insert方法去創(chuàng)建二叉排序樹,今天我們來(lái)給我們的數(shù)據(jù)結(jié)構(gòu)添加一些遍歷的功能。

二叉樹的三種遍歷方式(以根節(jié)點(diǎn)為準(zhǔn)來(lái)定義前、中、后)的介紹及其應(yīng)用場(chǎng)景:

前序遍歷

順序:根節(jié)點(diǎn) => 左子樹 => 右子樹

應(yīng)用:可以用來(lái)構(gòu)建文件的目錄結(jié)構(gòu),輸出所有目錄并分層

中序遍歷

順序:左子樹 => 根節(jié)點(diǎn) => 右子樹

應(yīng)用:可以進(jìn)行排序,輸出的結(jié)果是一個(gè)遞增的序列

后續(xù)遍歷

順序:左子樹 => 右子樹 => 根節(jié)點(diǎn)

應(yīng)用:后續(xù)遍歷是先遍歷子樹,最后到根節(jié)點(diǎn),可以實(shí)現(xiàn)統(tǒng)計(jì)節(jié)點(diǎn)數(shù)、計(jì)算文件夾大小的功能

思考

遍歷的方法是給誰(shuí)用的,是否需要暴露出去

如果暴露出去,怎樣設(shè)計(jì)才能讓調(diào)用者能夠獲取到每一個(gè)節(jié)點(diǎn)并且進(jìn)行對(duì)應(yīng)的操作

結(jié)論

肯定是要暴露出去給別人調(diào)用的

給別人調(diào)用,具體的邏輯是不確定的,所以應(yīng)該是調(diào)用者傳入一個(gè)函數(shù),我們?cè)诒闅v的時(shí)候把每一次的節(jié)點(diǎn)都傳給這個(gè)函數(shù),并且去調(diào)用這個(gè)函數(shù),這樣我們不用管具體函數(shù)的邏輯,反正已經(jīng)把它想要的 節(jié)點(diǎn) 給他了,具體怎樣操作我們不用管。

分析完畢之后,依然是上次的代碼,我們給他添加前序中序和后續(xù)遍歷的方法:

function BinaryTree(){
  var root = null; //根節(jié)點(diǎn)默認(rèn)為null
  //節(jié)點(diǎn)類型的構(gòu)造函數(shù)
  function Node(key){
    this.key = key;
    this.left = null;
    this.right = null;
  }
  //插入方法
  this.insert = function(key){     
    var newNode = new Node(key);
    if(root === null){
       root = newNode;
    }else{
       insertNode(root,newNode)
    }
  }
  var insertNode = function(node,newNode){
    if(newNode.key < node.key){
      if(node.left === null){
         node.left = newNode;
      }else{
         insertNode(node.left,newNode)
      }
    }else{
      if(newNode.key > node.key){
        if(node.right === null){
          node.right = newNode;
        }else{
          insertNode(node.right,newNode)
        }
      }
    }
  }
  
  /*--------------------------------------------------------*/
  /*
      前序遍歷: 根節(jié)點(diǎn) => 左子樹 => 右子樹
  */
  this.preTravel = function(callback){
    //和上面插入操作類似,都用一個(gè)內(nèi)部的函數(shù)來(lái)實(shí)現(xiàn)具體的邏輯,因?yàn)樾枰褂胷oot
     preTravelNode(root,callback); 
  }   
  /* 
      邏輯:
          1. 判斷傳入的節(jié)點(diǎn)是否為null,如果為null就直接return
          2. 如果不為null,則繼續(xù)對(duì)該節(jié)點(diǎn)下的left和right進(jìn)行遞歸調(diào)用
          3. 具體的調(diào)用順序根據(jù)為 根節(jié)點(diǎn) => 左子樹 => 右子樹
  */
  function preTravelNode(node,callback){
    if(node !== null){ 
       callback(node.key); 
       preTravelNode(node.left,callback);
       preTravelNode(node.right,callback);
    }
  }
  
  //中序遍歷
  this.middleTravel = function(callback){
    middleTravelNode(root,callback);
  }
  function middleTravelNode(node,callback){
    if(node !== null){
       middleTravelNode(node.left,callback);
       callback(node.key);
       middleTravelNode(node.right,callback);
    }
  }
  
  //后續(xù)遍歷
  this.nextTravel = function(callback){
    nextTravelNode(root,callback);
  }
  function nextTravelNode(node,callback){
    if(node !== null){
       nextTravelNode(node.left,callback);
       nextTravelNode(node.right,callback);
       callback(node.key);
    }
  }
}

var nodes = [8,7,3,4,6,5,2,9,12]
var binaryTree = new BinaryTree();
nodes.forEach((item)=>{
    binaryTree.insert(item)
})
//測(cè)試前序遍歷
binaryTree.beforeTravel((key)=>{
  console.log(key) // 8,7,3,2,4,6,5,9,10
})
console.log("--------------------")
//中序遍歷
binaryTree.middleTravel((key)=>{
  console.log(key) // 2,3,4,5,6,7,8,9,10
})
console.log("--------------------")
//后續(xù)遍歷
binaryTree.nextTravel((key)=>{
  console.log(key) // 2,5,6,4,3,7,10,9,8
})

具體的邏輯

判斷傳入的節(jié)點(diǎn)是否為null,如果為null就直接return

如果不為null,則繼續(xù)對(duì)該節(jié)點(diǎn)下的left和right進(jìn)行遞歸調(diào)用

具體的調(diào)用順序根據(jù)前序、中序、后序、的訪問(wèn)節(jié)點(diǎn)順序去修改調(diào)用的順序

還是放上這個(gè)二叉樹的圖,根據(jù)圖去對(duì)比測(cè)試的遍歷結(jié)果更直觀:

重點(diǎn)

怎樣設(shè)計(jì)遍歷方法,調(diào)用者傳什么東西進(jìn)來(lái),我們要暴露什么東西出去,這個(gè)地方得想明白

下期內(nèi)容

實(shí)現(xiàn)二叉樹的節(jié)點(diǎn)查找功能

實(shí)現(xiàn)二叉樹中節(jié)點(diǎn)的刪除功能

實(shí)現(xiàn)一個(gè)二叉樹的一個(gè)小游戲

上期內(nèi)容

使用javascript定義一個(gè)排序二叉樹

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/97120.html

相關(guān)文章

  • 使用javascript實(shí)現(xiàn)排序叉樹(1)

    摘要:使用實(shí)現(xiàn)排序二叉樹排序二叉樹的定義二叉樹的基礎(chǔ)上,左節(jié)點(diǎn)比父節(jié)點(diǎn)要小,右節(jié)點(diǎn)比父節(jié)點(diǎn)要大的二叉樹,叫排序二叉樹。下期內(nèi)容實(shí)現(xiàn)排序二叉樹的中序前序后續(xù)遍歷實(shí)現(xiàn)二叉樹的節(jié)點(diǎn)查找功能實(shí)現(xiàn)排序二叉樹的刪除節(jié)點(diǎn)功能應(yīng)用排序二叉樹實(shí)現(xiàn)一個(gè)小游戲 使用javascript實(shí)現(xiàn)排序二叉樹(1) 排序二叉樹的定義: 二叉樹的基礎(chǔ)上,左節(jié)點(diǎn)比父節(jié)點(diǎn)要小,右節(jié)點(diǎn)比父節(jié)點(diǎn)要大的二叉樹,叫排序二叉樹。 show...

    Caicloud 評(píng)論0 收藏0
  • JavaScript 數(shù)據(jù)結(jié)構(gòu)與算法之美 - 非線性表中的樹、堆是干嘛用的 ?其數(shù)據(jù)結(jié)構(gòu)是怎樣的 ?

    摘要:筆者寫的數(shù)據(jù)結(jié)構(gòu)與算法之美系列用的語(yǔ)言是,旨在入門數(shù)據(jù)結(jié)構(gòu)與算法和方便以后復(fù)習(xí)。非線性表中的樹堆是干嘛用的其數(shù)據(jù)結(jié)構(gòu)是怎樣的希望大家?guī)е@兩個(gè)問(wèn)題閱讀下文。其中,前中后序,表示的是節(jié)點(diǎn)與它的左右子樹節(jié)點(diǎn)遍歷訪問(wèn)的先后順序。 showImg(https://segmentfault.com/img/bVbuvnj?w=900&h=250); 1. 前言 想學(xué)好前端,先練好內(nèi)功,內(nèi)功不行,...

    singerye 評(píng)論0 收藏0
  • 學(xué)習(xí)javascript數(shù)據(jù)結(jié)構(gòu)(四)——樹

    摘要:原文博客地址學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu)四樹知乎專欄簡(jiǎn)書專題前端進(jìn)擊者知乎前端進(jìn)擊者簡(jiǎn)書博主博客地址的個(gè)人博客人之所能,不能兼?zhèn)洌瑮壠渌?,取其所長(zhǎng)。通常子樹被稱作左子樹和右子樹。敬請(qǐng)期待數(shù)據(jù)結(jié)構(gòu)篇最后一篇文章學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu)五圖參考文章樹數(shù)據(jù)結(jié)構(gòu)二叉樹 前言 總括: 本文講解了數(shù)據(jù)結(jié)構(gòu)中的[樹]的概念,盡可能通俗易懂的解釋樹這種數(shù)據(jù)結(jié)構(gòu)的概念,使用javascript實(shí)現(xiàn)了樹,如有紕漏,歡迎批評(píng)指正。 ...

    Dean 評(píng)論0 收藏0
  • 數(shù)據(jù)結(jié)構(gòu)與算法:叉樹算法

    摘要:因此,根據(jù)題目給出的先序遍歷和中序遍歷,可以畫出二叉樹選參考數(shù)據(jù)結(jié)構(gòu)與算法描述實(shí)現(xiàn)二叉樹算法淺談數(shù)據(jù)結(jié)構(gòu)二叉樹慕課網(wǎng)實(shí)現(xiàn)二叉樹算法前端樹控件騰訊軟件開發(fā)面試題 內(nèi)容銜接上一章 數(shù)據(jù)結(jié)構(gòu)與算法:常見排序算法 內(nèi)容提要 什么是樹   - 為什么使用樹 二叉樹 二叉查找樹 紅黑樹 B、B+樹 堆 伸展樹 樹 可以點(diǎn)擊鏈接感受下筆者用d3.js畫的tree https://codepen...

    Little_XM 評(píng)論0 收藏0
  • JavaScript實(shí)現(xiàn)簡(jiǎn)單二叉查找樹

    摘要:二叉查找樹二叉查找樹也叫二叉搜索樹它只允許我們?cè)谧蠊?jié)點(diǎn)存儲(chǔ)比父節(jié)點(diǎn)更小的值,右節(jié)點(diǎn)存儲(chǔ)比父節(jié)點(diǎn)更大的值,上圖展示的就是一顆二叉查找樹。 前兩天接到了螞蟻金服的面試電話,面試官很直接,上來(lái)就拋出了三道算法題。。。 其中有一道關(guān)于二叉樹實(shí)現(xiàn)中序遍歷的,當(dāng)時(shí)沒回答好,所以特意學(xué)習(xí)了一把二叉樹的知識(shí),行文記錄總結(jié)。 二叉樹&二叉查找樹 showImg(https://segmentfault....

    frank_fun 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<