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

Java二叉樹的四種遍歷(遞歸與非遞歸)

 更新時(shí)間:2021年10月07日 08:37:45   作者:funtrin  
這篇文章小編給大家分享的是Java二叉樹的四種遍歷,主要是遞歸與非遞歸,下面文章加u來詳細(xì)介紹,感興趣的小伙伴一起來學(xué)習(xí)吧

一、先序遍歷與后序遍歷

先序遍歷根節(jié)點(diǎn),再遍歷左子樹,再遍歷右子樹。

后序遍歷先遍歷左子樹,再遍歷右子樹,再遍歷根節(jié)點(diǎn)。

先序遍歷遞歸實(shí)現(xiàn):

public static void preOrderByRecursion(TreeNode root) {
    // 打印節(jié)點(diǎn)值
    System.out.println(root.value);
    preOrder(root.left);
    preOrder(root.right);
}

先序遍歷的非遞歸實(shí)現(xiàn):

非遞歸實(shí)現(xiàn)需要借助棧這樣一個(gè)數(shù)據(jù)結(jié)構(gòu),實(shí)際上遞歸實(shí)現(xiàn)也是依靠棧,只不過是隱式的。

  1. 先將根節(jié)點(diǎn)壓入棧中。
  2. 彈出棧中的節(jié)點(diǎn),將彈出節(jié)點(diǎn)的右子節(jié)點(diǎn)壓入棧中,再將彈出節(jié)點(diǎn)的左子樹壓入棧中。
  3. 重復(fù)步驟2,直到棧為空。
public static void preOrder(TreeNode root) {
    if (root == null) {
        return;
    }
    Stack<TreeNode> stack = new Stack<>();
    stack.push(root);
    while (!stack.empty()) {
        TreeNode node = stack.pop();
        // 打印節(jié)點(diǎn)值
        System.out.print(node.value + " ");
        if (node.right != null) {
            stack.push(node.right);
        }
        if (node.left != null) {
            stack.push(node.left);
        }
    }
}

后序遍歷遞歸實(shí)現(xiàn):先序遍歷反過來,就不贅述了。

public static void postOrderByRecursion(TreeNode root) {
    postOrderByRecursion(root.left);
    postOrderByRecursion(root.right);
    System.out.println(root.value);
}

后序遍歷非遞歸實(shí)現(xiàn):后序遍歷就是先序遍歷反過來,所以需要兩個(gè)棧,多出來的棧用來反向輸出。

public static void postOrder(TreeNode root) {
    if (root == null) {
        return;
    }
    Stack<TreeNode> s1 = new Stack<>();
    Stack<TreeNode> s2 = new Stack<>();
    s1.push(root);
    while (!s1.empty()) {
        TreeNode node = s1.pop();
        s2.push(node);
        if (node.left != null) {
            s1.push(node.left);
        }
        if (node.right != null) {
            s1.push(node.right);
        }
    }
    while (!s2.empty()) {
        System.out.println(s2.pop().value);
    }
}

二、中序遍歷

中序遍歷先遍歷左子樹,再遍歷根節(jié)點(diǎn),再遍歷右子樹。

遞歸遍歷:

public static void inOrderByRecursion(TreeNode root) {
    if (root == null) {
        return;
    }
    inOrderByRecursion(root.left);
    // 打印節(jié)點(diǎn)值
    System.out.println(root.value);
    inOrderByRecursion(root.right);
}

非遞歸遍歷:

  1. 將二叉樹的左側(cè)“邊”從上到下依次壓入棧中。
  2. 從棧中彈出節(jié)點(diǎn)
  3. 對(duì)以彈出節(jié)點(diǎn)的右子節(jié)點(diǎn)為根節(jié)點(diǎn)的子樹,重復(fù)步驟1。
  4. 重復(fù)2、3步驟,直到棧為空。
public static void inOrder(TreeNode root) {
    if (root == null) {
        return;
    }
    Stack<TreeNode> stack = new Stack<>();
    TreeNode cur = root;

    while (cur != null) {
        stack.push(cur);
        cur = cur.left;
    }

    while (!stack.empty()) {
        TreeNode node = stack.pop();
        System.out.println(node.value);
        cur = node.right;
        while (cur != null) {
            stack.push(cur);
            cur = cur.left;
        }
    }
}

三、層序遍歷

層序遍歷顧名思義就是一層一層,從左到右的遍歷二叉樹。需要用到隊(duì)列這一數(shù)據(jù)結(jié)構(gòu)。

  1. 將根節(jié)點(diǎn)推入隊(duì)列。
  2. 從隊(duì)列中取出一個(gè)節(jié)點(diǎn)。
  3. 先將取出節(jié)點(diǎn)的左子節(jié)點(diǎn)推入隊(duì)列,再將取出節(jié)點(diǎn)的右子節(jié)點(diǎn)推入隊(duì)列。
  4. 重復(fù)2、3步驟直到隊(duì)列中無節(jié)點(diǎn)可取。
public static void floorOrder(TreeNode root) {
    if (root == null) {
        return;
    }
    Queue<TreeNode> queue = new LinkedList<>();
    queue.add(root);
    while (!queue.isEmpty()) {
        TreeNode node = queue.poll();
        System.out.println(node.value);
        if (node.left != null) {
            queue.add(node.left);
        }
        if (node.right != null) {
            queue.add(node.right);
        }
    }
}

到此這篇關(guān)于Java二叉樹的四種遍歷(遞歸與非遞歸)的文章就介紹到這了,更多相關(guān)Java二叉樹的四種遍歷內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Spring?Boot?整合?FreeMarker?實(shí)例分享

    Spring?Boot?整合?FreeMarker?實(shí)例分享

    這篇文章主要分享了Spring?Boot整合FreeMarker?實(shí)例FreeMarker是一款模板引擎,即一種基于模板和要改變的數(shù)據(jù),并用來生成輸出文本,更多相關(guān)介紹需要的小伙伴可以參考下面文章內(nèi)容
    2022-05-05
  • MyBatis-Plus邏輯刪除和字段自動(dòng)填充的實(shí)現(xiàn)

    MyBatis-Plus邏輯刪除和字段自動(dòng)填充的實(shí)現(xiàn)

    本文主要介紹了MyBatis-Plus邏輯刪除和字段自動(dòng)填充的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • springboot中的pom文件?project報(bào)錯(cuò)問題

    springboot中的pom文件?project報(bào)錯(cuò)問題

    這篇文章主要介紹了springboot中的pom文件?project報(bào)錯(cuò)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • javaweb實(shí)現(xiàn)文件上傳小功能

    javaweb實(shí)現(xiàn)文件上傳小功能

    這篇文章主要為大家詳細(xì)介紹了javaweb實(shí)現(xiàn)文件上傳功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-06-06
  • Bean?Searcher配合SpringBoot的使用詳解

    Bean?Searcher配合SpringBoot的使用詳解

    這篇文章主要介紹了Bean?Searcher配合SpringBoot的使用,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-06-06
  • mybatis-plus enum實(shí)現(xiàn)枚舉類型自動(dòng)轉(zhuǎn)換

    mybatis-plus enum實(shí)現(xiàn)枚舉類型自動(dòng)轉(zhuǎn)換

    本文主要介紹了mybatis-plus enum實(shí)現(xiàn)枚舉類型自動(dòng)轉(zhuǎn)換,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-07-07
  • Java中的包(package)是什么和使用方法

    Java中的包(package)是什么和使用方法

    包是Java中一種強(qiáng)大的組織代碼的工具,它們幫助開發(fā)者將代碼分組,防止命名沖突,并通過控制訪問級(jí)別來增強(qiáng)代碼的安全性,這篇文章主要介紹了Java中的包(package)是什么和如何使用它們,需要的朋友可以參考下
    2024-07-07
  • Apache?log4j2-RCE?漏洞復(fù)現(xiàn)及修復(fù)建議(CVE-2021-44228)

    Apache?log4j2-RCE?漏洞復(fù)現(xiàn)及修復(fù)建議(CVE-2021-44228)

    Apache?Log4j2是一款Java日志框架,大量應(yīng)用于業(yè)務(wù)系統(tǒng)開發(fā)。2021年11月24日,阿里云安全團(tuán)隊(duì)向Apache官方報(bào)告了Apache?Log4j2遠(yuǎn)程代碼執(zhí)行漏洞(CVE-2021-44228),本文給大家介紹Apache?log4j2-RCE?漏洞復(fù)現(xiàn)(CVE-2021-44228)的相關(guān)知識(shí),感興趣的朋友一起看看吧
    2021-12-12
  • 多個(gè)java泛型示例分享

    多個(gè)java泛型示例分享

    這篇文章主要介紹了多個(gè)java泛型示例,需要的朋友可以參考下
    2014-04-04
  • Java編程Post數(shù)據(jù)請(qǐng)求和接收代碼詳解

    Java編程Post數(shù)據(jù)請(qǐng)求和接收代碼詳解

    這篇文章主要介紹了Java編程Post數(shù)據(jù)請(qǐng)求和接收代碼詳解,涉及enctype的三種編碼,post與get等相關(guān)內(nèi)容,具有一定參考價(jià)值,需要的朋友可以了解下。
    2017-11-11

最新評(píng)論