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

Java實現(xiàn)二叉樹的示例代碼(遞歸&迭代)

 更新時間:2022年03月17日 15:24:42   作者:愛干飯的猿  
二叉樹(Binary?tree)是樹形結(jié)構(gòu)的一個重要類型。本文將利用Java語言實現(xiàn)二叉樹,文中的示例代碼講解詳細(xì),需要的同學(xué)可以參考一下

1.二叉樹基本概念見上節(jié):詳解Java中二叉樹的基礎(chǔ)概念(遞歸&迭代)

2.本次展示鏈?zhǔn)酱鎯?/p>

以此圖為例,完整代碼如下:

//基礎(chǔ)二叉樹實現(xiàn)
//使用左右孩子表示法
 
import java.util.*;
import java.util.Deque;
 
public class myBinTree {
    private static class TreeNode{
        char val;
        TreeNode left;
        TreeNode right;
 
        public TreeNode(char val) {
            this.val = val;
        }
    }
 
    public static TreeNode build(){
        TreeNode nodeA=new TreeNode('A');
        TreeNode nodeB=new TreeNode('B');
        TreeNode nodeC=new TreeNode('C');
        TreeNode nodeD=new TreeNode('D');
        TreeNode nodeE=new TreeNode('E');
        TreeNode nodeF=new TreeNode('F');
        TreeNode nodeG=new TreeNode('G');
        TreeNode nodeH=new TreeNode('H');
        nodeA.left=nodeB;
        nodeA.right=nodeC;
        nodeB.left=nodeD;
        nodeB.right=nodeE;
        nodeE.right=nodeH;
        nodeC.left=nodeF;
        nodeC.right=nodeG;
        return nodeA;
    }
 
    //方法1(遞歸)
    //先序遍歷: 根左右
    public static void preOrder(TreeNode root){
        if(root==null){
            return;
        }
        System.out.print(root.val+" ");
        preOrder(root.left);
        preOrder(root.right);
    }
 
    //方法1(遞歸)
    //中序遍歷
    public static void inOrder(TreeNode root){
        if(root==null){
            return;
        }
        inOrder(root.left);
        System.out.print(root.val+" ");
        inOrder(root.right);
    }
 
    //方法1(遞歸)
    //后序遍歷
    public static void postOrder(TreeNode root){
        if(root==null){
            return;
        }
        postOrder(root.left);
        postOrder(root.right);
        System.out.print(root.val+" ");
    }
 
    //方法2(迭代)
    //先序遍歷 (迭代)
    public static void preOrderNonRecursion(TreeNode root){
        if(root==null){
            return ;
        }
        Deque<TreeNode> stack=new LinkedList<>();
        stack.push(root);
        while (!stack.isEmpty()){
            TreeNode cur=stack.pop();
            System.out.print(cur.val+" ");
            if(cur.right!=null){
                stack.push(cur.right);
            }
            if(cur.left!=null){
                stack.push(cur.left);
            }
        }
    }
 
    //方法2(迭代)
    //中序遍歷 (迭代)
    public static void inorderTraversalNonRecursion(TreeNode root) {
        if(root==null){
            return ;
        }
 
        Deque<TreeNode> stack=new LinkedList<>();
        // 當(dāng)前走到的節(jié)點(diǎn)
        TreeNode cur=root;
        while (!stack.isEmpty() || cur!=null){
            // 不管三七二十一,先一路向左走到根兒~
            while (cur!=null){
                stack.push(cur);
                cur=cur.left;
            }
            // 此時cur為空,說明走到了null,此時棧頂就存放了左樹為空的節(jié)點(diǎn)
            cur=stack.pop();
            System.out.print(cur.val+" ");
            // 繼續(xù)訪問右子樹
            cur=cur.right;
        }
    }
 
    //方法2(迭代)
    //后序遍歷 (迭代)
    public static void postOrderNonRecursion(TreeNode root){
        if(root==null){
            return;
        }
        Deque<TreeNode> stack=new LinkedList<>();
        TreeNode cur=root;
        TreeNode prev=null;
 
        while (!stack.isEmpty() || cur!=null){
            while (cur!=null){
                stack.push(cur);
                cur=cur.left;
            }
 
            cur=stack.pop();
            if(cur.right==null || prev==cur.right){
                System.out.print(cur.val+" ");
                prev=cur;
                cur=null;
            }else {
                stack.push(cur);
                cur=cur.right;
            }
        }
    }
 
    //方法1(遞歸)
    //傳入一顆二叉樹的根節(jié)點(diǎn),就能統(tǒng)計出當(dāng)前二叉樹中一共有多少個節(jié)點(diǎn),返回節(jié)點(diǎn)數(shù)
    //此時的訪問就不再是輸出節(jié)點(diǎn)值,而是計數(shù)器 + 1操作
    public static int getNodes(TreeNode root){
        if(root==null){
            return 0;
        }
        return 1+getNodes(root.left)+getNodes(root.right);
    }
 
    //方法2(迭代)
    //使用層序遍歷來統(tǒng)計當(dāng)前樹中的節(jié)點(diǎn)個數(shù)
    public static int getNodesNoRecursion(TreeNode root){
        if(root==null){
            return 0;
        }
        int size=0;
        Deque<TreeNode> queue=new LinkedList<>();
        queue.offer(root);
        while (!queue.isEmpty()) {
            TreeNode cur = queue.poll();
            size++;
            if (cur.left != null) {
                queue.offer(cur.left);
            }
            if (cur.right != null) {
                queue.offer(cur.right);
            }
        }
        return size;
    }
 
    //方法1(遞歸)
    //傳入一顆二叉樹的根節(jié)點(diǎn),就能統(tǒng)計出當(dāng)前二叉樹的葉子結(jié)點(diǎn)個數(shù)
    public static int getLeafNodes(TreeNode root){
        if(root==null){
            return 0;
        }
        if(root.left==null && root.right==null){
            return 1;
        }
        return getLeafNodes(root.left)+getLeafNodes(root.right);
    }
 
    //方法2(迭代)
    //使用層序遍歷來統(tǒng)計葉子結(jié)點(diǎn)的個數(shù)
    public static int getLeafNodesNoRecursion(TreeNode root){
        if(root==null){
            return 0;
        }
        int size=0;
        Deque<TreeNode> queue=new LinkedList<>();
        queue.offer(root);
        while (!queue.isEmpty()){
            TreeNode cur=queue.poll();
            if(cur.left==null && cur.right==null){
                size++;
            }
            if(cur.left!=null){
                queue.offer(cur.left);
            }
            if(cur.right!=null){
                queue.offer(cur.right);
            }
        }
        return size;
    }
 
    //層序遍歷
    public static void levelOrder(TreeNode root) {
        if(root==null){
            return ;
        }
 
        // 借助隊列來實現(xiàn)遍歷過程
        Deque<TreeNode> queue =new LinkedList<>();
        queue.offer(root);
        while (!queue.isEmpty()){
            int size=queue.size();
            for (int i = 0; i < size; i++) {
                TreeNode cur=queue.poll();
                System.out.print(cur.val+" ");
                if(cur.left!=null){
                    queue.offer(cur.left);
                }
                if(cur.right!=null){
                    queue.offer(cur.right);
                }
            }
        }
    }
 
    //傳入一個以root為根節(jié)點(diǎn)的二叉樹,就能求出該樹的高度
    public static int height(TreeNode root){
        if(root==null){
            return 0;
        }
        return 1+ Math.max(height(root.left),height(root.right));
    }
 
    //求出以root為根節(jié)點(diǎn)的二叉樹第k層的節(jié)點(diǎn)個數(shù)
    public static int getKLevelNodes(TreeNode root,int k){
        if(root==null || k<=0){
            return 0;
        }
        if(k==1){
            return 1;
        }
        return getKLevelNodes(root.left,k-1)+getKLevelNodes(root.right,k-1);
    }
 
    //判斷當(dāng)前以root為根節(jié)點(diǎn)的二叉樹中是否包含指定元素val,
    //若存在返回true,不存在返回false
    public static boolean contains(TreeNode root,char value){
        if(root==null){
            return false;
        }
        if(root.val==value){
            return true;
        }
        return contains(root.left,value) || contains(root.right,value);
    }
 
 
    public static void main(String[] args) {
        TreeNode root=build();
 
        System.out.println("方法1(遞歸):前序遍歷的結(jié)果為:");
        preOrder(root);
        System.out.println();
        System.out.println("方法2(迭代):前序遍歷的結(jié)果為:");
        preOrderNonRecursion(root);
        System.out.println();
 
        System.out.println("方法1(遞歸):中序遍歷的結(jié)果為:");
        inOrder(root);
        System.out.println();
        System.out.println("方法2(迭代):中序遍歷的結(jié)果為:");
        inorderTraversalNonRecursion(root);
        System.out.println();
 
        System.out.println("方法1(遞歸):后序遍歷的結(jié)果為:");
        postOrder(root);
        System.out.println();
        System.out.println("方法2(迭代):后序遍歷的結(jié)果為:");
        postOrderNonRecursion(root);
        System.out.println();
        System.out.println();
 
        System.out.println("層序遍歷的結(jié)果為:");
        levelOrder(root);
        System.out.println();
        System.out.println();
 
        System.out.println("方法1(遞歸):當(dāng)前二叉樹一共有:"+getNodes(root)+"個節(jié)點(diǎn)數(shù)");
        System.out.println("方法2(迭代):當(dāng)前二叉樹一共有:"+getNodesNoRecursion(root)+"個節(jié)點(diǎn)數(shù)");
        System.out.println("方法1(遞歸):當(dāng)前二叉樹一共有:"+getLeafNodes(root)+"個葉子節(jié)點(diǎn)數(shù)");
        System.out.println("方法2(迭代):當(dāng)前二叉樹一共有:"+getLeafNodesNoRecursion(root)+"個葉子節(jié)點(diǎn)數(shù)");
        System.out.println(contains(root,'E'));
        System.out.println(contains(root,'P'));
        System.out.println("當(dāng)前二叉樹的高度為:"+height(root));
        System.out.println("當(dāng)前二叉樹第3層的節(jié)點(diǎn)個數(shù)為:"+getKLevelNodes(root,3));
    }
}

如上main引用結(jié)果如下:

到此這篇關(guān)于Java實現(xiàn)二叉樹的示例代碼(遞歸&迭代)的文章就介紹到這了,更多相關(guān)Java二叉樹內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • IDEA創(chuàng)建Maven項目后報錯不出現(xiàn)src文件夾的情況解決

    IDEA創(chuàng)建Maven項目后報錯不出現(xiàn)src文件夾的情況解決

    最近剛開始學(xué)習(xí)maven,正準(zhǔn)備使用idea創(chuàng)建一個maven項目練手,卻發(fā)現(xiàn)自己創(chuàng)建的maven項目始終沒有src目錄,下面這篇文章主要給大家介紹了關(guān)于IDEA創(chuàng)建Maven項目后報錯不出現(xiàn)src文件夾的情況解決,需要的朋友可以參考下
    2023-05-05
  • mybatis使用Integer類型查詢可能出現(xiàn)的問題

    mybatis使用Integer類型查詢可能出現(xiàn)的問題

    這篇文章主要介紹了mybatis使用Integer類型查詢可能出現(xiàn)的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • Feign調(diào)用全局異常處理解決方案

    Feign調(diào)用全局異常處理解決方案

    這篇文章主要介紹了Feign調(diào)用全局異常處理解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • MyBatis攔截器的原理與使用

    MyBatis攔截器的原理與使用

    本文全面的講解了MyBatis攔截器的作用原理及使用方法,攔截器的使用可以提升開發(fā)效率,學(xué)習(xí)MyBatis的朋友不妨了解下本文
    2021-06-06
  • SpringBoot2.x設(shè)置Session失效時間及失效跳轉(zhuǎn)方式

    SpringBoot2.x設(shè)置Session失效時間及失效跳轉(zhuǎn)方式

    這篇文章主要介紹了SpringBoot2.x設(shè)置Session失效時間及失效跳轉(zhuǎn)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • 基于Java在netty中實現(xiàn)線程和CPU綁定

    基于Java在netty中實現(xiàn)線程和CPU綁定

    這篇文章主要介紹了基于Java在netty中實現(xiàn)線程和CPU綁定,文章圍繞主題的相關(guān)內(nèi)容展開詳細(xì)介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-05-05
  • Spring Boot自定義錯誤視圖的方法詳解

    Spring Boot自定義錯誤視圖的方法詳解

    這篇文章主要介紹了Spring Boot自定義錯誤視圖的方法詳解,需要的朋友可以參考下
    2020-08-08
  • 一文讀懂Jvm類加載機(jī)制

    一文讀懂Jvm類加載機(jī)制

    這篇文章主要介紹了一文讀懂Jvm類加載機(jī)制,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-07-07
  • java中String字符串刪除空格的七種方式

    java中String字符串刪除空格的七種方式

    在Java中從字符串中刪除空格有很多不同的方法,本文主要介紹了java中String字符串刪除空格的七種方式,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • 一文秒懂java到底是值傳遞還是引用傳遞

    一文秒懂java到底是值傳遞還是引用傳遞

    這篇文章主要介紹了java到底是值傳遞還是引用傳遞的相關(guān)知識,本文通過幾個例子給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-06-06

最新評論