亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

java基礎二叉搜索樹圖文詳解

 更新時間:2022年03月10日 12:53:42   作者:Dark?And?Grey  
二叉樹是一種非常重要的數(shù)據(jù)結構,它同時具有數(shù)組和鏈表各自的特點,下面這篇文章主要給大家介紹了關于java基礎二叉搜索樹的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下

概念

二叉搜索樹又稱二叉排序樹,它或者是一棵空樹,或者是具有以下性質的二叉樹:
1、若它的左子樹不為空,則左子樹上所有節(jié)點的值都小于根結點的值。
2、若它的右子樹不為空,則右子樹上所有節(jié)點的值都大于根結點的值。
3、它的左右子樹也分別為二叉搜索樹

直接實踐

準備工作:定義一個樹節(jié)點的類,和二叉搜索樹的類。

搜索二叉樹的查找功能

假設我們已經構造好了一個這樣的二叉樹,如下圖

我們要思考的第一個問題是如何查找某個值是否在該二叉樹中?

根據(jù)上述的邏輯,我們來把搜索的方法進行完善。

搜索二叉樹的插入操作

根據(jù)上述邏輯,我們來寫一個插入節(jié)點的代碼。

搜索二叉樹 刪除節(jié)點的操作 - 難點

再來分析一下:curDummy 和 parentDummy 是怎么找到“替罪羊”的。

總程序 - 模擬實現(xiàn)二叉搜索樹

class TreeNode{
    public int val;
    public TreeNode left;
    public TreeNode right;
    public TreeNode(int val){
        this.val = val;
    }
}


public class BinarySearchTree {
    TreeNode root;

    //在二叉樹中 尋找指定 val 值的節(jié)點
    // 找到了,返回其節(jié)點地址;沒找到返回 null
    public TreeNode search(int key){
        TreeNode cur = this.root;
        while(cur != null){
            if(cur.val == key){
                return cur;
            }else if(cur.val < key){
                cur = cur.right;
            }else{
                cur = cur.left;
            }
        }
        return null;
    }
    // 插入操作
    public boolean insert(int key){
        if(this.root == null){
            this.root = new TreeNode(key);
            return true;
        }
        TreeNode cur = this.root;
        TreeNode parent = null;
        while(cur!=null){
            if(key > cur.val){
                parent  = cur;
                cur = cur.right;
            }else if(cur.val == key){
                return false;
            }else{
                parent  = cur;
                cur = cur.left;
            }
        }
        TreeNode node = new TreeNode(key);
        if(parent .val > key){
            parent.left = node;
        }else{
            parent.right = node;
        }
        return true;
    }
    // 刪除操作
    public void remove(int key){
        TreeNode cur = root;
        TreeNode parent = null;
        // 尋找 刪除節(jié)點位置。
        while(cur!=null){
            if(cur.val == key){
                removeNode(cur,parent);// 真正刪除節(jié)點的代碼
                break;
            }else if(cur.val < key){
                parent = cur;
                cur = cur.right;
            }else{
                parent = cur;
                cur = cur.left;
            }
        }
    }
    // 輔助刪除方法:真正刪除節(jié)點的代碼
    private void removeNode(TreeNode cur,TreeNode parent){
        // 情況一
        if(cur.left == null){
            if(cur == this.root){
                this.root = this.root.right;
            }else if( cur == parent.left){
                parent.left = cur.right;
            }else{
                parent.right = cur.right;
            }
            // 情況二
        }else if(cur.right == null){
            if(cur == this.root){
                this.root = root.left;
            }else if(cur == parent.left){
                parent.left = cur.left;
            }else{
                parent.right = cur.left;
            }
            // 情況三
        }else{
            // 第二種方法:在刪除節(jié)點的右子樹中尋找最小值,
            TreeNode parentDummy = cur;
            TreeNode curDummy = cur.right;
            while(curDummy.left != null){
                parentDummy = curDummy;
                curDummy = curDummy.left;
            }
            // 此時 curDummy 指向的 cur 右子樹
            cur.val = curDummy.val;
            if(parentDummy.left != curDummy){
                parentDummy.right = curDummy.right;
            }else{
                parentDummy.left = curDummy.right;
            }

        }
    }
   // 中序遍歷
    public void inorder(TreeNode root){
        if(root == null){
            return;
        }
        inorder(root.left);
        System.out.print(root.val+" ");
        inorder(root.right);
    }

    public static void main(String[] args) {
        int[] array = {10,8,19,3,9,4,7};
        BinarySearchTree binarySearchTree = new BinarySearchTree();
        for (int i = 0; i < array.length; i++) {
            binarySearchTree.insert(array[i]);
        }
        binarySearchTree.inorder(binarySearchTree.root);
        System.out.println();// 換行
        System.out.print("插入重復的數(shù)據(jù) 9:" + binarySearchTree.insert(9));
        System.out.println();// 換行
        System.out.print("插入不重復的數(shù)據(jù) 1:" + binarySearchTree.insert(1));
        System.out.println();// 換行
        binarySearchTree.inorder(binarySearchTree.root);
        System.out.println();// 換行
        binarySearchTree.remove(19);
        System.out.print("刪除元素 19 :");
        binarySearchTree.inorder(binarySearchTree.root);
        System.out.println();// 換行
        System.out.print("查找不存在的數(shù)據(jù)50 :");
        System.out.println(binarySearchTree.search(50));
        System.out.print("查找存在的數(shù)據(jù) 7:");
        System.out.println(binarySearchTree.search(7));
    }
}

性能分析

  插入和刪除操作都必須先查找,查找效率代表了二叉搜索樹中各個操作的性能。

  對有n個結點的二叉搜索樹,若每個元素查找的概率相等,則二叉搜索樹平均查找長度是結點在二叉搜索樹的深度的函數(shù),即結點越深,則比較次數(shù)越多。

  但對于同一個關鍵碼集合,如果各關鍵碼插入的次序不同,可能得到不同結構的二叉搜索樹:

如果我們能保證 二叉搜索樹的左右子樹高度差不超過1。盡量滿足高度平衡條件。
這就成 AVL 樹了(高度平衡的二叉搜索樹)。而AVL樹,也有缺點:需要一個頻繁的旋轉。浪費很多效率。
至此 紅黑樹就誕生了,避免更多的旋轉。

和 java 類集的關系

TreeMap 和 TreeSet 即 java 中利用搜索樹實現(xiàn)的 Map 和 Set;實際上用的是紅黑樹,而紅黑樹是一棵近似平衡的二叉搜索樹,即在二叉搜索樹的基礎之上 + 顏色以及紅黑樹性質驗證,關于紅黑樹的內容,等博主學了,會寫博客的。

總結 

到此這篇關于java基礎二叉搜索樹的文章就介紹到這了,更多相關java二叉搜索樹內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Spring中@Value注解詳細圖文講解

    Spring中@Value注解詳細圖文講解

    在spring中有兩種注入方式一種是XML文件注入,另一種則是注解注入,這篇文章主要給大家介紹了關于Spring中@Value注解的相關資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2023-11-11
  • Java POI讀取excel中數(shù)值精度損失問題解決

    Java POI讀取excel中數(shù)值精度損失問題解決

    這篇文章主要介紹了Java POI讀取excel中數(shù)值精度損失問題解決,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-04-04
  • 詳解mybatis foreach collection示例

    詳解mybatis foreach collection示例

    這篇文章主要介紹了詳解mybatis foreach collection的相關資料,需要的朋友可以參考下
    2017-10-10
  • mybatis plus saveBatch方法方法執(zhí)行慢導致接口發(fā)送慢解決分析

    mybatis plus saveBatch方法方法執(zhí)行慢導致接口發(fā)送慢解決分析

    這篇文章主要為大家介紹了mybatis plus saveBatch方法導致接口發(fā)送慢解決分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-10-10
  • 基于java時區(qū)轉換夏令時的問題及解決方法

    基于java時區(qū)轉換夏令時的問題及解決方法

    下面小編就為大家分享一篇基于java時區(qū)轉換夏令時的問題及解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2017-11-11
  • spring boot配置讀寫分離的完整實現(xiàn)步驟

    spring boot配置讀寫分離的完整實現(xiàn)步驟

    數(shù)據(jù)庫配置主從之后,如何在代碼層面實現(xiàn)讀寫分離?所以下面這篇文章主要給大家介紹了關于spring boot配置讀寫分離的完整步驟,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2018-09-09
  • 一文詳解Java線程的6種狀態(tài)與生命周期

    一文詳解Java線程的6種狀態(tài)與生命周期

    一個線程在給定的時間點只能處于一種狀態(tài)。線程可以有6種狀態(tài):New、Runnable、Blocked、Waiting、Timed?waiting和Terminated。本文將詳細講解這6種狀態(tài),需要的可以參考一下
    2022-05-05
  • 深入理解Spring Boot的日志管理

    深入理解Spring Boot的日志管理

    這篇文章主要給大家深入的介紹了Spring Boot日志管理的相關資料,文中介紹的很詳細,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-02-02
  • SpringBoot實現(xiàn)短信驗證碼校驗方法思路詳解

    SpringBoot實現(xiàn)短信驗證碼校驗方法思路詳解

    最近做項目遇到這樣的需求,前端是基于BootStrap,html代碼中有BootStrap樣式實現(xiàn)的,具體后臺實現(xiàn)代碼大家通過本文一起學習吧
    2017-08-08
  • idea中如何全局搜索class文件或者字符串

    idea中如何全局搜索class文件或者字符串

    這篇文章主要介紹了idea中如何實現(xiàn)全局搜索class文件或者字符串問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03

最新評論