Java二叉搜索樹遍歷操作詳解【前序、中序、后序、層次、廣度優(yōu)先遍歷】
本文實例講述了Java二叉搜索樹遍歷操作。分享給大家供大家參考,具體如下:
前言:在上一節(jié)Java二叉搜索樹基礎(chǔ)中,我們對樹及其相關(guān)知識做了了解,對二叉搜索樹做了基本的實現(xiàn),下面我們繼續(xù)完善我們的二叉搜索樹。
對于二叉樹,有深度遍歷和廣度遍歷,深度遍歷有前序、中序以及后序三種遍歷方法,廣度遍歷即我們尋常所說的層次遍歷,如圖:

因為樹的定義本身就是遞歸定義,所以對于前序、中序以及后序這三種遍歷我們使用遞歸的方法實現(xiàn),而對于廣度優(yōu)先遍歷需要選擇其他數(shù)據(jù)結(jié)構(gòu)實現(xiàn),本例中我們使用隊列來實現(xiàn)廣度優(yōu)先遍歷。
四種基本的遍歷思想為:
前序遍歷:根結(jié)點 ---> 左子樹 ---> 右子樹
中序遍歷:左子樹---> 根結(jié)點 ---> 右子樹
后序遍歷:左子樹 ---> 右子樹 ---> 根結(jié)點
層次遍歷:從上到下,從左到右。
比如,以下二叉樹的各種遍歷:

前序遍歷: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é)點 ---> 左子樹 ---> 右子樹,代碼實現(xiàn)如下:
//二分搜索樹的前序遍歷(前序遍歷:根結(jié)點 ---> 左子樹 ---> 右子樹)
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é)點 ---> 右子樹,代碼實現(xiàn)如下:
//二分搜索樹的中序遍歷(中序遍歷:左子樹---> 根結(jié)點 ---> 右子樹)
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é)點,代碼實現(xiàn)如下:
//二分搜索樹的后序遍歷(后序遍歷:左子樹 ---> 右子樹 ---> 根結(jié)點)
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);
}
四、層次遍歷
對于層次遍歷,我們基于隊列來實現(xiàn),思路如下:
(1)先在隊列中增加根結(jié)點
(2)對于隨意其余任意節(jié)點,在其出隊列的時候訪問(假設(shè)左孩子和右孩子有不為空的情況,入隊列)
代碼實現(xiàn)如下:
//層次遍歷--(基于隊列實現(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é)點技巧總結(jié)》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總》
希望本文所述對大家java程序設(shè)計有所幫助。
相關(guān)文章
JavaEE簡介_動力節(jié)點Java學(xué)院整理
這篇文章主要介紹了JavaEE簡介,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-07-07
IDEA編譯報錯“java: 常量字符串過長”的原因及解決方法
今天在開發(fā)過程中,由于嘗試將一個文件的 Base64 字符串設(shè)置為常量,結(jié)果導(dǎo)致 IDEA 編譯的時候出現(xiàn)了如下報錯java: 常量字符串過長,所以本文給大家記錄了IDEA編譯報錯“java: 常量字符串過長”的原因及解決方法,需要的朋友可以參考下2025-02-02
SpringBoot?使用AOP?+?Redis?防止表單重復(fù)提交的方法
Spring?Boot是一個用于構(gòu)建Web應(yīng)用程序的框架,通過AOP可以實現(xiàn)防止表單重復(fù)提交,本文介紹了在Spring?Boot應(yīng)用程序中使用AOP和Redis來防止表單重復(fù)提交的方法,需要的朋友可以參考下2023-04-04
Spring中的ContextLoaderListener詳細解析
這篇文章主要介紹了Spring中的ContextLoaderListener詳細解析,在web容器即Tomact容器啟動web應(yīng)用即servlet應(yīng)用時,會觸發(fā)ServletContextEvent時間,這個事件會被ServletContextListener監(jiān)聽,需要的朋友可以參考下2023-12-12
Spring Cloud Netflix架構(gòu)淺析(小結(jié))
這篇文章主要介紹了Spring Cloud Netflix架構(gòu)淺析(小結(jié)),詳解的介紹了Spring Cloud Netflix的概念和組件等,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-01-01
Spring Boot啟動過程(五)之Springboot內(nèi)嵌Tomcat對象的start教程詳解
這篇文章主要介紹了Spring Boot啟動過程(五)之Springboot內(nèi)嵌Tomcat對象的start的相關(guān)資料,需要的朋友可以參考下2017-04-04
Java?SpringBoot?@Async實現(xiàn)異步任務(wù)的流程分析
這篇文章主要介紹了Java?SpringBoot?@Async實現(xiàn)異步任務(wù),主要包括@Async?異步任務(wù)-無返回值,@Async?異步任務(wù)-有返回值,@Async?+?自定義線程池的操作代碼,需要的朋友可以參考下2022-12-12

