K:樹與二叉樹

来源:https://www.cnblogs.com/MyStringIsNotNull/archive/2018/01/11/8270798.html
-Advertisement-
Play Games

相關介紹:  樹(英語:tree)是一種抽象數據類型(ADT)或是作這種抽象數據類型的數據結構,用來模擬具有樹狀結構性質的數據集合。它是由n(n 0)個有限節點組成的一個具有層次關係的集合。把它叫做“樹”是因為它看起來像一棵倒掛的樹,也就是說它是根朝上,而葉朝下的。樹形結構中數據元素之間具 ...


相關介紹:

 樹(英語:tree)是一種抽象數據類型(ADT)或是作這種抽象數據類型的數據結構,用來模擬具有樹狀結構性質的數據集合。它是由n(n>0)個有限節點組成的一個具有層次關係的集合。把它叫做“樹”是因為它看起來像一棵倒掛的樹,也就是說它是根朝上,而葉朝下的。樹形結構中數據元素之間具有一對多的邏輯關係,它反映了數據元素之間的層次關係,一個數據元素可以有多個後繼,但最多只能有一個前驅。二叉樹是樹裡面的一個特殊形態,每個節點最多只有兩個分支(不存在分支度大於2的節點)。通常分支被稱作“左子樹”和“右子樹”。二叉樹的分支具有左右次序,不能顛倒。

以下介紹樹相關的知識點:

  1. 樹的定義:樹是由n(n>=0)個節點所構成的有限集合,當n=0時,稱之為空樹;當n>0時,n各節點,滿足以下的情況:

    • 有且僅有一個稱之為根的節點。
    • 其餘節點可分為m(m>=0)個互不相交的有限集合,且每一個集合又構成一棵樹,這棵樹稱為根節點的子樹。
  2. 樹的表示方法:樹形表示法(最為常用)、文氏圖表示法、凹入圖表示法、廣義表示法。圖1.1展示了樹的這四種表示方法。

圖1.1,即樹的表示方法

  1. 樹的常用術語

    • 樹的節點:由一個數據元素及關聯其子樹的邊所組成

    • 節點的路徑:從根節點到該節點所經歷的分支和節點的順序排列

    • 路徑的長度:指節點路徑中所包含的分支數,也就是路徑的節點數目減一。例如有一路徑A->B->C->D,則其路徑長度為3

    • 節點的度:該節點擁有的子樹的數目

    • 樹的度:樹中所有節點的度的最大值

    • 葉節點(終端節點):樹中度為0的節點

    • 分支節點(非終端節點、內部節點):樹中度不為0的節點。在樹中,除了葉節點外的所有節點都是分支節點

    • 孩子節點(子節點):一個節點的孩子節點是指這個節點的子樹的根節點

    • 雙親節點(父節點):若樹中某個節點有孩子節點,則這個節點就稱為孩子節點的雙親節點。雙親節點和孩子節點也稱為是具有互為前驅和後繼關係的節點

    • 子孫節點:一個節點的子孫節點是指這個節點的所有子樹中的任意節點

    • 祖先節點:一個節點的祖先節點是指該節點的路徑中除此節點之外的所有節點

    • 兄弟節點:具有同一雙親的節點稱為兄弟節點

    • 節點的層次:假設根節點的層次為0,則其它節點的層次是雙親節點的 層次數加一

    • 樹的深度:樹中所有節點層次數的最大值加一

    • 有序樹:樹中各節點的所有子樹之間從左到右有嚴格的次序關係

    • 無序樹:與有序樹相反,無序樹是指樹中各節點的所有子樹之間沒有嚴格的次序關係

    • 森林:由m(m>=0)棵互不相交的樹所構成的集合

二叉樹是一棵特殊的樹,它的每個節點最多只有兩棵子樹,並且這兩棵子樹也是二叉樹,由於二叉樹中的兩棵子樹有左右之分,為此,二叉樹是有序樹。

  1. 二叉樹的基本概念:二叉樹是由n(n>=0)個節點所構成的有限集合。當n=0時,這個集合為空,此時的二叉樹為空樹;當n>0時,這個集合是由一個根節點和兩個互不相交的分別稱為左子樹和右子樹的二叉樹所構成。

  2. 滿二叉樹:如果在一棵二叉樹中,它的所有節點或者是葉節點,或者是左、右子樹都非空,並且所有葉節點都在同一層上,則稱這棵二叉樹為滿二叉樹。

  3. 完全二叉樹:如果在一棵具有n個節點的二叉樹中,它的邏輯結構與滿二叉樹的前n個節點的邏輯結構相同,則稱這樣的二叉樹為完全二叉樹。完全二叉樹其只允許缺少的葉節點在右半部分,而不允許在左半部分。下圖1.2展示了滿二叉樹和完全二叉樹,完全二叉樹與非完全二叉樹之間的區別。

完全二叉樹也滿二叉樹,完全二叉樹與非完全二叉樹

  1. 二叉樹的性質

    • 在二叉樹的第i層上至多有\(2^{i}\)個節點(i>=0)

    • 深度為h(h>=0)的二叉樹上至多含有\(2^{h}-1\)個節點

    • 對於任何一棵二叉樹,若其葉節點的個數為N0,度數為2的節點的個數為N2,則有N0=N2+1。證明過程如下:

    設二叉樹中度為1的節點個數為n1,二叉樹的節點總數為n,則有:
    n=n0+n1+n2
    
    再設二叉樹中具有e個分支,而度為1的節點是引出一個分支,度為2的節點是引出兩個分支,則有:
    e=n1+n2*2
    
    又因為在二叉樹中,除根節點外,每個節點均對應一個進入它的分支,所以有:
    n=e+1
    
    整合以上各式,得到n0=n2+1
    • 具有n個節點的完全二叉樹的深度為\(\lfloor log_{2}N \rfloor+1\)或者\(\lceil log_{2}(N+1) \rceil\)

    • 若對含n個節點的完全二叉樹從上到下,且從左到右進行0至n-1的編號,則對完全二叉樹中任意一個編號為i的節點,有:

      1. 若i=0,則該節點是二叉樹的根,無雙親;否則,編號為\(\lfloor \frac{i-1}{2} \rfloor\)的節點為其雙親節點

      2. 若2i+1>=n,則該節點無左孩子節點,否則,編號為2i+1的節點為其左孩子節點

      3. 若2i+2>=n,則該節點無右孩子節點,否則,編號為2i+2的節點為其右孩子節點

樹與二叉樹的區別:

 從二叉樹的定義中可以看出,二叉樹與樹有著很大的不同,它們的區別在於:

  1. 樹中的每個節點可以有多棵子樹,而二叉樹中的每個節點最多只能有2棵子樹
  2. 樹中的子樹是不分順序的,而二叉樹中的子樹有嚴格的左、右之分
  3. 二叉樹與度小於等於2的樹不同。在二叉樹中允許某些節點只有右子樹而沒有左子樹,而在樹中,一個節點若沒有第一棵子樹,則它就不可能有第二棵子樹的存在。

回到目錄|·(工)·)


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

-Advertisement-
Play Games
更多相關文章
  • 關於flask_script flask_script擴展提供向Flask插入外部腳本的功能,包括運行一個開發用的伺服器,一個定製的Python shell,設置資料庫的腳本,cronjobs,及其他運行在web應用之外的命令行任務;使得腳本和系統分開; Flask Script和Flask本身的工 ...
  • 前言 我們最初的javaSE部分學習後,基本算是入門了,也熟悉了Java的語法和一些常用API,然後再深入到資料庫操作、WEB程式開發,漸漸會接觸到JDBC、Servlet/Jsp之類的知識,期間可能會接觸一兩個關係型資料庫,例如MySQL/Oracle等等。像前面的MyBatis部分,主要是針對J ...
  • Django中內置的signal Django中提供了"信號調度",用於在框架執行操作時解耦. 一些動作發生的時候,系統會根據信號定義的函數執行相應的操作 Model_signals pre_init # Django中的model對象執行其構造方法前,自動觸發 post_init # Django ...
  • (一)函數指針 定義:如果在程式中定義了一個函數,在編譯時,編譯系統為函數代碼分配一段存儲空間,這段存儲空間的起始地址稱為這個函數的指針。 (二)使用函數指針變數調用函數 小例子,取最大值 可見,定義指向函數的指針變數的一般格式類型名 (*指針變數名)(函數參數列表)int (*p) (int ,i ...
  • Github地址: https://github.com/ccyinghua/appEleme-project 一、構建項目所用: 二、組件腦圖 三、markdown項目說明 Mock.md - 模擬json數據 Header.md - 頭部組件開發說明 Goods.md - 商品組件開發說明 Fo ...
  • System類,系統類,包含的是靜態方法,無法創建對象 這裡介紹幾個簡單的方法,其他一些在後邊用到的時候會講 類方法: currentTimeMillis():獲取當前毫秒數 exit()方法:退出JVM虛擬機 gc()方法:收取對象的垃圾,這個不需要舉例,知道即可 getProperties()方 ...
  • 在Java遇到了將類似“1|2|3|4”的字元串分隔為數組的功能 這種問題能難倒有著十多年開發經驗的的.NET碼農? 結果,出來的數組是這個鬼樣子 1,|,2,|,3 仔細看看split傳入的參數名,regex,是正則表達式,恍然大悟,要轉義正則表達式…… 問題解決後,繼續手賤研究這個split,尋 ...
  • 這裡介紹基本數據類型包裝類,Integer是int的包裝類, 其他的基本數據類型的包裝類的方法和Integer的方法幾乎一致,會一種即可全會 基本數據類型包裝類的特點:用於在基本數據類型和字元串之間進行轉換 這些類屬於java的核心類,不需要import Integer類的方法: parseInt方 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...