<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
二元搜尋樹又稱二叉排序樹,它或者是一棵空樹,或者是具有以下性質的二元樹:
1、若它的左子樹不為空,則左子樹上所有節點的值都小於根結點的值。
2、若它的右子樹不為空,則右子樹上所有節點的值都大於根結點的值。
3、它的左右子樹也分別為二元搜尋樹
假設我們已經構造好了一個這樣的二元樹,如下圖
我們要思考的第一個問題是如何查詢某個值是否在該二元樹中?
根據上述的邏輯,我們來把搜尋的方法進行完善。
根據上述邏輯,我們來寫一個插入節點的程式碼。
再來分析一下:curDummy 和 parentDummy 是怎麼找到“替罪羊”的。
class TreeNode{ public int val; public TreeNode left; public TreeNode right; public TreeNode(int val){ this.val = val; } } public class BinarySearchTree { TreeNode root; //在二元樹中 尋找指定 val 值的節點 // 找到了,返回其節點地址;沒找到返回 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; // 尋找 刪除節點位置。 while(cur!=null){ if(cur.val == key){ removeNode(cur,parent);// 真正刪除節點的程式碼 break; }else if(cur.val < key){ parent = cur; cur = cur.right; }else{ parent = cur; cur = cur.left; } } } // 輔助刪除方法:真正刪除節點的程式碼 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{ // 第二種方法:在刪除節點的右子樹中尋找最小值, 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("插入重複的資料 9:" + binarySearchTree.insert(9)); System.out.println();// 換行 System.out.print("插入不重複的資料 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("查詢不存在的資料50 :"); System.out.println(binarySearchTree.search(50)); System.out.print("查詢存在的資料 7:"); System.out.println(binarySearchTree.search(7)); } }
插入和刪除操作都必須先查詢,查詢效率代表了二元搜尋樹中各個操作的效能。
對有n個結點的二元搜尋樹,若每個元素查詢的概率相等,則二元搜尋樹平均查詢長度是結點在二元搜尋樹的深度的函數,即結點越深,則比較次數越多。
但對於同一個關鍵碼集合,如果各關鍵碼插入的次序不同,可能得到不同結構的二元搜尋樹:
如果我們能保證 二元搜尋樹的左右子樹高度差不超過1。儘量滿足高度平衡條件。
這就成 AVL 樹了(高度平衡的二元搜尋樹)。而AVL樹,也有缺點:需要一個頻繁的旋轉。浪費很多效率。
至此 紅黑樹就誕生了,避免更多的旋轉。
TreeMap 和 TreeSet 即 java 中利用搜尋樹實現的 Map 和 Set;實際上用的是紅黑樹,而紅黑樹是一棵近似平衡的二元搜尋樹,即在二元搜尋樹的基礎之上 + 顏色以及紅黑樹性質驗證,關於紅黑樹的內容,等博主學了,會寫部落格的。
到此這篇關於java基礎二元搜尋樹的文章就介紹到這了,更多相關java二元搜尋樹內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45