欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java二叉搜索樹遍歷操作詳解【前序、中序、后序、層次、廣度優(yōu)先遍歷】

 更新時(shí)間:2020年03月19日 14:27:17   作者:WFaceBoss  
這篇文章主要介紹了Java二叉搜索樹遍歷操作,結(jié)合實(shí)例形式詳細(xì)分析了Java二叉搜索樹前序、中序、后序、層次、廣度優(yōu)先遍歷等相關(guān)原理與操作技巧,需要的朋友可以參考下

本文實(shí)例講述了Java二叉搜索樹遍歷操作。分享給大家供大家參考,具體如下:

前言:在上一節(jié)Java二叉搜索樹基礎(chǔ)中,我們對(duì)樹及其相關(guān)知識(shí)做了了解,對(duì)二叉搜索樹做了基本的實(shí)現(xiàn),下面我們繼續(xù)完善我們的二叉搜索樹。

對(duì)于二叉樹,有深度遍歷和廣度遍歷,深度遍歷有前序、中序以及后序三種遍歷方法,廣度遍歷即我們尋常所說的層次遍歷,如圖:

因?yàn)闃涞亩x本身就是遞歸定義,所以對(duì)于前序、中序以及后序這三種遍歷我們使用遞歸的方法實(shí)現(xiàn),而對(duì)于廣度優(yōu)先遍歷需要選擇其他數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn),本例中我們使用隊(duì)列來實(shí)現(xiàn)廣度優(yōu)先遍歷。

四種基本的遍歷思想為:

前序遍歷:根結(jié)點(diǎn) ---> 左子樹 ---> 右子樹
中序遍歷:左子樹---> 根結(jié)點(diǎn) ---> 右子樹
后序遍歷:左子樹 ---> 右子樹 ---> 根結(jié)點(diǎn)
層次遍歷:從上到下,從左到右。

比如,以下二叉樹的各種遍歷:

前序遍歷:5-3-2-4-6-8
中序遍歷:2-3-4-5-6-8
后序遍歷:2-4-3-8-6-5
層次遍歷:5-3-6-2-4-8

一、前序遍歷

依據(jù)上文提到的遍歷思路:根結(jié)點(diǎn) ---> 左子樹 ---> 右子樹,代碼實(shí)現(xiàn)如下:

 //二分搜索樹的前序遍歷(前序遍歷:根結(jié)點(diǎn) ---> 左子樹 ---> 右子樹)
  public void preOrder() {
    preOrder(root);
  }

  //前序遍歷以node為根的二分搜索樹,遞歸算法
  private void preOrder(Node node) {
    if (node == null) {
      return;
    }
    System.out.println(node.e);
    preOrder(node.left);
    preOrder(node.right);
  }

二、中序遍歷

依據(jù)上文提到的遍歷思路:左子樹 ---> 根結(jié)點(diǎn) ---> 右子樹,代碼實(shí)現(xiàn)如下:

  //二分搜索樹的中序遍歷(中序遍歷:左子樹---> 根結(jié)點(diǎn) ---> 右子樹)
  public void inOrder() {
    inOrder(root);
  }

  //中序遍歷以node為根的二分搜索樹,遞歸算法
  private void inOrder(Node node) {
    if (node == null) {
      return;
    }
    inOrder(node.left);
    System.out.println(node.e);
    inOrder(node.right);
  }

三、后序遍歷

依據(jù)上文提到的遍歷思路:左子樹 ---> 右子樹 ---> 根結(jié)點(diǎn),代碼實(shí)現(xiàn)如下:

  //二分搜索樹的后序遍歷(后序遍歷:左子樹 ---> 右子樹 ---> 根結(jié)點(diǎn))
  public void postOrder() {
    postOrder(root);
  }

  //后序遍歷以node為根的二分搜索樹,遞歸算法
  private void postOrder(Node node) {
    if (node == null) {
      return;
    }
    postOrder(node.left);
    postOrder(node.right);
    System.out.println(node.e);
  }

四、層次遍歷

對(duì)于層次遍歷,我們基于隊(duì)列來實(shí)現(xiàn),思路如下:
(1)先在隊(duì)列中增加根結(jié)點(diǎn)
(2)對(duì)于隨意其余任意節(jié)點(diǎn),在其出隊(duì)列的時(shí)候訪問(假設(shè)左孩子和右孩子有不為空的情況,入隊(duì)列)
代碼實(shí)現(xiàn)如下:

//層次遍歷--(基于隊(duì)列實(shí)現(xiàn))
  public void levelOrder() {

    Queue<Node> q = new LinkedList<>();
    q.add(root);

    while (!q.isEmpty()) {
      Node cur = q.remove();
      System.out.println(cur.e);
      if (cur.left != null) {
        q.add(cur.left);
      }
      if (cur.right!=null){
        q.add(cur.right);
      }
    }
  }

源代碼地址 https://github.com/FelixBin/dataStructure/blob/master/src/BST/BST.java

更多關(guān)于java算法相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Java數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Java操作DOM節(jié)點(diǎn)技巧總結(jié)》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總

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

相關(guān)文章

  • windows 32位eclipse遠(yuǎn)程hadoop開發(fā)環(huán)境搭建

    windows 32位eclipse遠(yuǎn)程hadoop開發(fā)環(huán)境搭建

    這篇文章主要介紹了windows 32位eclipse遠(yuǎn)程hadoop開發(fā)環(huán)境搭建的相關(guān)資料,需要的朋友可以參考下
    2016-07-07
  • mybatis plus in方法使用詳解

    mybatis plus in方法使用詳解

    這篇文章主要介紹了mybatis plus in方法使用詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • 使用Java DOM解析器修改XML文件內(nèi)容的操作方法

    使用Java DOM解析器修改XML文件內(nèi)容的操作方法

    在Java中,XML文件的解析和修改可以通過多種方法實(shí)現(xiàn),其中DOM(Document Object Model)是一種常用的方式,在本文中,我們將介紹如何使用Java DOM解析器修改XML文件中的內(nèi)容,并給出一個(gè)具體的示例,需要的朋友可以參考下
    2024-08-08
  • Java 實(shí)現(xiàn)FTP服務(wù)實(shí)例詳解

    Java 實(shí)現(xiàn)FTP服務(wù)實(shí)例詳解

    這篇文章主要介紹了Java 實(shí)現(xiàn)FTP服務(wù)實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下
    2017-04-04
  • Java利用Reflect實(shí)現(xiàn)封裝Excel導(dǎo)出工具類

    Java利用Reflect實(shí)現(xiàn)封裝Excel導(dǎo)出工具類

    這篇文章主要為大家詳細(xì)介紹了Java如何利用Reflect實(shí)現(xiàn)封裝Excel導(dǎo)出工具類,文中的實(shí)現(xiàn)方法講解詳細(xì),具有一定的借鑒價(jià)值,需要的可以參考一下
    2022-11-11
  • 詳解使用spring validation完成數(shù)據(jù)后端校驗(yàn)

    詳解使用spring validation完成數(shù)據(jù)后端校驗(yàn)

    這篇文章主要介紹了詳解使用spring validation完成數(shù)據(jù)后端校驗(yàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • Java中對(duì)XML的解析詳解

    Java中對(duì)XML的解析詳解

    目前我知道的JAVA解析XML的方式有:DOM, SAX, StAX;如果選用這幾種,感覺還是有點(diǎn)麻煩;如果使用:JAXB(Java Architecture for XML Binding),個(gè)人覺得太方便了
    2013-05-05
  • Swing拆分窗格控件JSplitPane使用詳解

    Swing拆分窗格控件JSplitPane使用詳解

    這篇文章主要為大家詳細(xì)介紹了Swing拆分窗格控件JSplitPane的使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • Spring?IOC?常用注解與使用實(shí)例詳解

    Spring?IOC?常用注解與使用實(shí)例詳解

    這篇文章主要介紹了Spring?IOC?常用注解與使用,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-06-06
  • intellij idea旗艦版解決學(xué)生無法注冊(cè)問題詳解

    intellij idea旗艦版解決學(xué)生無法注冊(cè)問題詳解

    這篇文章主要介紹了intellij idea旗艦版解決學(xué)生無法注冊(cè)問題詳解,文中通過圖文示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07

最新評(píng)論