二叉排序樹

来源:http://www.cnblogs.com/xidongyu/archive/2016/10/26/6001430.html
-Advertisement-
Play Games

定義 若左子樹非空,則左子樹上所有結點關鍵字值均小於根節點關鍵字值 若右子樹非空,則右子樹上所有節點關鍵字值均大於根節點關鍵字值 左,右子樹分別是一顆二叉排序樹 二叉排序樹插入 二查排序樹插入定義:若原二叉樹為空,則直接插入節點。否則,若關鍵字K小於根節點關鍵字,則插入到左子樹中。若關鍵字K大於根節... ...


定義

  • 若左子樹非空,則左子樹上所有結點關鍵字值均小於根節點關鍵字值
  • 若右子樹非空,則右子樹上所有節點關鍵字值均大於根節點關鍵字值
  • 左,右子樹分別是一顆二叉排序樹

二叉排序樹插入

二查排序樹插入定義:若原二叉樹為空,則直接插入節點。否則,若關鍵字K小於根節點關鍵字,則插入到左子樹中。若關鍵字K大於根節點關鍵字,則插入到右子樹當中。插入的時間複雜度是樹高O(H)

public void insert(Node p, int k) {
        if (p != null) {
            if (k < p.val)
                if (p.LChild == null) {
                    p.LChild = new Node();
                    p.LChild.val = k;
                } else
                    insert(p.LChild, k);
            else {
                if (p.RChild == null) {
                    p.RChild = new Node();
                    p.RChild.val = k;
                } else
                    insert(p.RChild, k);
            }
        }
}

二叉排序樹的刪除

刪除分三種情況:

  • 如果被刪除的節點是葉子節點,就直接刪除
  • 如果被刪除的節點只有左子樹或右子樹,則將其左子樹或右子樹代替該節點
  • 如果左右子樹都存在,那麼則將其右子樹中序遍歷的第一個節點First替換該節點(值替換),並將First從樹中刪除
  • 刪除節點的時間複雜度為O(H)
public void delete(int k) {
        Node parent = new Node();
        parent.LChild = node;
        Node p = node;
        Node t = null;
        // 找出欲刪除的節點P
        while (p != null && p.val != k) {
            parent = p;
            if (k < p.val)
                p = p.LChild;
            else
                p = p.RChild;
        }
        // 欲刪節點的左右孩子都不為空
        if (p.LChild != null && p.RChild != null) {
            // 找出p的後繼節點(中序遍歷)
            Node post = inOrderFisrt(p.RChild);
            // 將後繼節點值copy給p
            p.val = post.val;
            // 將欲刪除的節點修改為post節點
            p = post;
        }
        // 欲刪節點的左孩子或右孩子為空
        if (p.LChild == null)
            t = p.RChild;
        else if (p.RChild == null)
            t = p.LChild;
        if (p == parent.LChild)
            parent.LChild = t;
        else
            parent.RChild = t;
    }

中序遍歷查找第一個節點

private Node inOrderFisrt(Node t) {
        Node p = null;
        while (t != null) {
            p = t;
            t = t.LChild;
        }
        return p;
    }

二叉排序樹構造


在構造二查排序樹時,只需要不斷調用二叉排序樹的插入演算法即可。下麵的代碼是不斷從一個數組中取出欲插入的數,然後調用insert方法將其插入到二叉樹當中。

private void initBST(Node node, int[] arr) {
        for (int i = 1; i < arr.length; i++) {
            insert(node, arr[i]);
        }
    }

二叉排序樹的查找

查找演算法用遞歸實現,每次查找時都與根節點進行比較,如果小於根節點,則往左子樹上走。否則,向右子樹上走。

public Node search(Node p, int k) {
        if (p != null) {
            if (p.val == k)
                return p;
            else {
                if (k > p.val)
                    return search(p.RChild, k);
                else
                    return search(p.LChild, k);
            }
        } else
            return null;
    }

查找效率分析

二叉排序樹的查找效率和樹的構造有關。如果樹的左右子樹高度相當,那麼查找效率為O(logN),否則效率就很低,最低為O(N)。列如下麵兩棵樹,同樣找節點70,則左邊的效率明顯比右邊的高。

image


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、前言 生命不息,折騰不止。近期公司有數據遷移的計劃,從Sqlserver遷移到mysql,雖說網上有很多數據遷移方案,但閑著也是閑著,就自己整一個,權當做是練練手了 二、解決思路 整個遷移過程類似於ETL,將數據從來源端經過抽取(extract)、轉換(transform)、載入(load)至目 ...
  • 1、查詢當前用戶的所有表(自己的表) 2、查詢Oracle中所有的系統許可權,一般是DBA 3、查詢Oracle所有的角色,一般是DBA; 4、查詢Oracle中所有對象許可權 5、查詢資料庫的表空間 6、查詢當前用戶具有什麼樣的系統許可權 7、查詢當前用戶在其他用戶的表上具有什麼樣的對象許可權 8、查看某 ...
  • 好久不用mysql,今天突然想用的時候, mysql -uroot -p 直接報了下麵的錯誤 ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2) mac可以在設置裡面 ...
  • TensorBoard簡介 Tensorflow發佈包中提供了TensorBoard,用於展示Tensorflow任務在計算過程中的Graph、定量指標圖以及附加數據。大致的效果如下所示, TensorBoard工作機制 TensorBoard 通過讀取 TensorFlow 的事件文件來運行。Te ...
  • 廣義完整性:語義完整性,併發控制,安全控制,故障恢復 狹義完整性:專指語義完整性 完整性涉及實體完整性,參照完整性,用戶自定義完整性 DBMS保證完整性 由資料庫管理員來定義完整性規則,當用戶進行資料庫操作時。先由完整性控製程序根據完整性規則來檢查請求是否合法,如果合法則交給DBMS執行更新操作。 ... ...
  • 資料庫版本:11GR2 一、介紹 在oracle中沒有其他資料庫系統中的資料庫的概念,對象都是創建在用戶下。當前用戶具有當前用戶下所有對象的所有許可權無論該對象是否是當前用戶所創建。舉個簡單例子創建一個用戶授予該用戶連接許可權,然後用管理員用戶在該用戶下創建一張表,該用戶可以刪除管理員在該用戶下創建的表 ...
  • 1. 確保Java已經正確安裝。 查看Java版本:java -version 2. 下載hadoop源程式並解壓到apache的官網下載某一版本的hadoop,不同版本可能會存在較大差異。本教程中使用版本為2.7.1 https://dist.apache.org/repos/dist/relea ...
  • Zookeeper概論(對zookeeper的概論、原理、架構等的理解) 一、概論 Zookeeper是一個分散式的、開放源碼的分散式應用程式協調服務,是Google的Chubby一個開源的實現,是hadoop和hbase 的重要組件。它是一個為分散式應用提供一致性服務的軟體。提供的功能包括:配置維 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...