NOI大綱——普及組——二叉搜索樹

二叉搜索樹

二叉搜索樹(Binary Search Tree,簡稱BST)是一種特殊的二叉樹,它具有以下幾個特點:

  1. 節點的左子樹上的所有節點的值都小于或等于該節點的值
  2. 節點的右子樹上的所有節點的值都大于或等于該節點的值
  3. 每個節點的左右子樹也都是二叉搜索樹

這些特點使得二叉搜索樹在進行搜索、插入和刪除操作時非常高效。具體來說,在平均情況下,這些操作的時間復雜度都是 (O(\log n)),其中 (n) 是樹中的節點數。

二叉搜索樹的基本操作

  1. 搜索(Search)

    • 從根節點開始,比較目標值與當前節點的值:

      • 如果目標值等于當前節點的值,則搜索成功;

      • 如果目標值小于當前節點的值,則在左子樹中繼續搜索;

      • 如果目標值大于當前節點的值,則在右子樹中繼續搜索。

  2. 插入(Insert)

    • 從根節點開始,找到目標值應該插入的位置,保持二叉搜索樹的性質。
    • 如果目標值小于當前節點的值,則插入到左子樹中;
    • 如果目標值大于當前節點的值,則插入到右子樹中。
  3. 刪除(Delete)

    • 刪除操作稍微復雜一些,分為三種情況:
      1. 要刪除的節點是葉子節點(沒有子節點),直接刪除即可。
      2. 要刪除的節點有一個子節點,用該子節點替代要刪除的節點。
      3. 要刪除的節點有兩個子節點,需要找到該節點的中序后繼(右子樹中最小的節點)或中序前驅(左子樹中最大的節點),用這個節點的值替換要刪除的節點的值,然后刪除這個節點。

示例

假設我們有以下一組數據:[5, 3, 8, 2, 4, 7, 9],構建的二叉搜索樹如下:

      5/ \3   8/ \ / \2  4 7  9
  • 搜索 4:從根節點 5 開始,4 < 5,往左走;到達 3 節點,4 > 3,往右走;到達 4 節點,找到目標值。
  • 插入 6:從根節點 5 開始,6 > 5,往右走;到達 8 節點,6 < 8,往左走;到達 7 節點,6 < 7,往左走,插入 6 節點。
  • 刪除 3:節點 3 有兩個子節點,找到 4(中序后繼)替換 3,然后刪除節點 4

二叉搜索樹因其高效的操作性能,在許多應用中被廣泛使用,如數據庫索引和內存中的數據結構。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/37484.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/37484.shtml
英文地址,請注明出處:http://en.pswp.cn/web/37484.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

ActiveMq工具之管理頁面說明

文章目錄 安裝ActiveMQ一: 訪問管理頁面二: 進入管理頁面&#xff0c;主頁三: Queues頁說明四: Topics頁說明五: Subscribers頁說明 安裝ActiveMQ wget https://archive.apache.org/dist//activemq/5.13.3/apache-activemq-5.13.3-bin.tar.gz wget https://mirrors.huaweiclou…

為什么越來越多的企業選擇外包?賦能企業未來

軟件開發過程包括設計需求、設計方案、產品研發、產品交付、后期維護&#xff0c;許多企業并沒有軟件開發的專業能力與工作經驗&#xff0c;將軟件開發工作進行外包是比較節約成本的&#xff0c;企業能少走不少彎路。 YesPMP平臺&#xff08;一站式軟件外包、項目外包服務-YesP…

UWA Pipeline 2.6.1版本更新

UWA Pipeline是專為游戲開發團隊設計的本地協作平臺&#xff0c;旨在幫助團隊建立專業的DevOps研發交付流水線。本平臺提供了可視化的CI/CD操作界面&#xff0c;高可用的自動化測試和無縫集成的UWA性能保障服務等核心功能。 在最新的Pipeline更新中&#xff0c;UWA引入了參數配…

protobufjs解析proto消息出錯RangeError: index out of range: 2499 + 10 > 2499解決辦法

使用websocket通訊傳輸protobuf消息的時候&#xff0c;decode的時候出錯了&#xff1a; RangeError: index out of range: 2499 10 > 2499 Error: invalid wire type 4 at offset 1986 出現這種錯誤的時候&#xff0c;99%是因為proto里面的消息類型和服務端發送的消息類型不…

vue表頭字段添加鼠標懸浮提示

<el-table-column prop"jfScore" align"center" min-width"100px"><template slot"header" slot-scope"scope"><div><span>信用積分</span><el-tooltip:aa"scope"class"it…

Java錯題歸納(二)

1、若有如下接口A的定義&#xff0c;下列哪些類下確實現了該接口&#xff1a;C interface A { void method1(int i); void method2(int j); } A class B implements A{ void method1( ) { } void method2( ) { } } B class B implements A { void method1(int i ) { }…

關于windows,wifi圖標顯示不了的解決方法

解決方法一&#xff08;解決了我的問題的方法&#xff09;&#xff1a; winr -->輸入 regedit 打開注冊表 --> 刪除HKEY-CLASSES_ROOT\CLSID\{3d09c1ca-2bcc-40b7-b9bb-3f3ec143a87b} CLSID在下面仔細找&#xff0c;然后找到09開頭那個刪掉重啟就可以了&#xff0c;可能…

別小看ai智能語音機器人但也別神話它電銷機器人部署語音識別‘次數活動

人類社會的發展不斷在加速&#xff0c;現代人對新事物接納的速度變得越來越快&#xff0c;進而對新事物、新模式的期待也越來越多、頻率越來越高。 僅聚焦在電銷領域&#xff0c;當將視線回撥&#xff0c;我們會發現作為新技術與新模式的代表&#xff0c;電銷從20世紀中后期引進…

CAS服務端部署

部署CAS Cas服務端其實就是一個war包。 在資源\cas\source\cas-server-4.0.0-release\cas-server-4.0.0\modules目錄下cas-server-webapp-4.0.0.war 將其改名為cas.war放入tomcat目錄下的webapps下。啟動tomcat自動解壓war包。瀏覽器輸入 登錄頁面 http://localhost:8080/ca…

nuxt3搭建和部署

Nuxt 3是一個基于Vue 3的靜態網站生成框架&#xff0c;它提供了高性能、SEO友好的Web應用程序開發體驗。Nuxt 3重寫了許多核心代碼&#xff0c;增加了新功能&#xff0c;如基于Vite的構建系統、改進的路由系統、數據獲取和插件系統。它支持TypeScript和多種渲染模式&#xff08…

20240701 每日AI必讀資訊

&#x1f3eb;AI真煉丹&#xff1a;整整14天&#xff0c;無需人類參與 - 英矽智能推出全球首個AI參與決策的生物學實驗室&#xff0c;實現了14天內完成靶點發現和驗證的全自動化閉環實驗。 - 該實驗室由PandaOmics平臺驅動&#xff0c;集成多種預測模型和海量數據&#xff0…

conda安裝d2l教程

前言 提前安裝anaconda為什么直接安裝d2l會出錯&#xff1f;- 因為python版本問題&#xff0c;最好的解決辦法就是利用conda來建立一個虛擬的環境 第一步 創建新的虛擬環境 打開conda命令行&#xff0c;也就是anaconda prompt輸入下面的命令 conda create --name d2l pytho…

【Python】從基礎到進階(二):了解Python語言基礎以及數據類型轉換、基礎輸入輸出

&#x1f525; 個人主頁&#xff1a;空白詩 文章目錄 一、引言二、基本數據類型轉換1. 隱式轉換2. 顯式轉換 三、基本輸入輸出1. 輸入&#xff08;input&#xff09;2. 輸出&#xff08;print&#xff09;3. 案例&#xff1a;輸入姓名、年齡、身高以及體重&#xff0c;計算BMI指…

《從零開始學習大語言模型》專欄來啦!

歡迎來到我的專欄LLM-from-scratch&#xff0c;這是一個致力于從零開始學習和掌握大語言模型的知識寶庫。無論你是剛入門的新手&#xff0c;還是想要深入了解的高級用戶&#xff0c;這里都有適合你的內容。以下是專欄的精彩章節&#xff1a; LLM-from-scratch-1.圖解tokenizat…

DM表級觸發器

可以理解為行變動級 觸發體中寫邏輯 這是表修改時調用存儲過程 感謝大哥分享: https://blog.csdn.net/WuLex/article/details/83181449 感謝大哥分享: https://blog.csdn.net/ChennyWJS/article/details/131913198

湘潭大學軟件工程信息與網絡安全復習筆記最后一篇

文章目錄 復習建議分數占比流密碼A5/1RC4 分組密碼DESAES 復習建議 現在筆者復習算是收尾了&#xff0c;現在也是考前的最后一天了&#xff0c;走了不少彎路&#xff0c;但是可能也是必不可少的&#xff0c;復習建議是硬著頭皮把這份文件看一遍&#xff0c;不理解的地方找英文…

如何使用sr2t將你的安全掃描報告轉換為表格格式

關于sr2t sr2t是一款針對安全掃描報告的格式轉換工具&#xff0c;全稱為“Scanning reports to tabular”&#xff0c;該工具可以獲取掃描工具的輸出文件&#xff0c;并將文件數據轉換為表格格式&#xff0c;例如CSV、XLSX或文本表格等&#xff0c;能夠為廣大研究人員提供一個…

軟件接口自動化測試

使用軟件工具工裝治具測試 在當今快速迭代的軟件開發環境中&#xff0c;確保軟件質量與高效交付成為了每個開發團隊的首要任務。軟件接口作為系統之間交互的關鍵橋梁&#xff0c;其穩定性和可靠性直接影響到整個應用生態的性能。因此&#xff0c;軟件接口自動化測試成為了提升…

在 Python 中將字典內容保存到 Excel 文件

目錄&#xff1a; 使用 Pandas 轉 Excel使用 Openpyxl 轉 Excel使用 xlsxwriter 轉 Excel使用 csv 轉 Excel Python 中的字典是一個數據集合&#xff0c;其中每個值對應一個鍵。它們是無序的、可變的&#xff0c;并且對字典中存儲的值和鍵的數據類型沒有限制。Python 程序員經常…

【SpringCloud】Ribbon源碼解析

ribbon是一個負載均衡組件&#xff0c;它可以將請求分散到多個服務提供者實例中&#xff0c;提高系統的性能和可用性。本章分析ribbon是如何實現負載均衡的 1、LoadBalanced 消費者在引入ribbon組件后&#xff0c;給http客戶端添加LoadBalanced注解就能啟用負載均衡功能。Load…