【自考】數據結構第四章樹和二叉樹,期末不掛科指南,第6篇

来源:https://www.cnblogs.com/happymeng/archive/2020/01/08/shujujiegou_6.html
-Advertisement-
Play Games

章節簡介 前5篇博客寫的都是線性結構,對於有層級結構的數據需要用樹形結構來描述 本章的重要知識點 1. 理解有關樹的基本概念和二叉樹的基本概念 2. 掌握二叉樹的存儲結構以及遍歷方法 3. 掌握樹的存儲結構以及樹、森林、二叉樹的相互轉換方法 4. 梳理掌握哈夫曼樹構造方法和哈夫曼編碼的設計方法 樹的 ...


章節簡介

前5篇博客寫的都是線性結構,對於有層級結構的數據需要用樹形結構來描述

本章的重要知識點

  1. 理解有關樹的基本概念和二叉樹的基本概念
  2. 掌握二叉樹的存儲結構以及遍歷方法
  3. 掌握樹的存儲結構以及樹、森林、二叉樹的相互轉換方法
  4. 梳理掌握哈夫曼樹構造方法和哈夫曼編碼的設計方法

樹的基本概念

核心一句話

線性結構中一個結點至多只有一個直接後繼,樹形結構一個結點可以有一個或多個直接後繼

認識樹

看圖即可,你要能區分出來哪些是樹,哪些不是樹

樹的相關術語

  1. 結點的度:樹上任意結點所擁有的子樹的數目稱為該結點的度

  2. 葉子:度為0的結點稱為葉子或者終端結點

  3. 樹的度:一棵樹中所有結點的度的最大值稱為該樹的度,就是把所有結點的度求和
  4. 結點的層次:從根算起,根的層次為1,其餘結點的層次為其雙親的層次加1

  5. 樹的高度:一棵樹中所有結點層次數的最大值稱為該樹的高度或深度
  6. 還有一些小概念:有序樹、無序樹

樹的相關術語,一定要一開始就明確清晰,後面才好學習

二叉樹

官方概念:二叉樹是n(n≥0)個元素的有限集合,該集合或者為空,或者由一個根及兩棵互不相交的左子樹和右子樹組成,其中左子樹和右子樹也均為二叉樹。二叉樹的任一結點都有兩棵子樹(它們中的任何一個都可以是空子樹),並且這兩棵子樹之間有次序關係,交換位置就成為一棵不同的二叉樹。

左子樹和右子樹,也有的叫做左孩子和右孩子

二叉樹五種基本形態,方塊表示子樹

二叉樹的基本運算(不寫代碼,瞭解重點函數即可)

  1. 初始化
  2. 求雙親
  3. 求左孩子
  4. 求右孩子
  5. 建二叉樹
  6. 先序遍歷!!!
  7. 中序遍歷!!!
  8. 後序遍歷!!!
  9. 層次遍歷!!!
    先序遍歷,中序遍歷,後序遍歷在考試中一般不要求手寫代碼,但是需要你能通過一棵樹結構,輸出最終的結果,這個博客結尾給大家看一下例題

二叉樹性質(很重要,細碎知識點很多)

性質1:二叉樹第i(i≥1)層上至多有2^i-1^個結點。

不需要死記硬背,實際需要的時候畫一個二叉樹就可以求出來了

性質2:深度為k(k≥1)的二叉樹至多有2^k^-1個結點

依舊可以推導出來
深度為1的二叉樹 結點最多為1
深度為2的二叉樹 結點最多為3
深度為3的二叉樹 結點最多為7
深度為k的二叉樹 結點最多為2^k^-1

性質3:對任何一棵二叉樹,若度數為0的結點(葉結點)個數為n~0~,度數為2的結點個數為n~2~,則n~0~ = n~2~+1

這個性質需要稍微推導一下
先回答一個問題,你知道樹的度數,怎麼計算樹的結點數
例如 樹的度數為2,結點樹為幾,這個不難想象,會出現如下情況

看到這裡不難發現,存在一個公式為 樹的度數+1=樹的結點樹
那麼我們開始推導上述公式
假設 二叉樹的0度,1度,2度結點個數為n~0~,n~1~,n~2~,結點總數為T
T = n~0~+n~1~+n~2~
樹的度數+1 = T
樹的度數怎麼求?n~0~0+n~1~1+n~2~2 是樹的度數
繼續n~0~
0+n~1~1+n~2~2 +1 = T = n~0~+n~1~+n~2~
===> 2n~2~+1=n~0~+n~2~
===>n~0~=n~2~+1

好了,上述過程,爭取看明白吧

性質4:含有n個結點的完全二叉樹的深度為

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

-Advertisement-
Play Games
更多相關文章
  • 背景 By 魯迅 By 高爾基 說明: 1. Kernel版本:4.14 2. ARM64處理器,Contex A53,雙核 3. 使用工具:Source Insight 3.5, Visio 1. 概述 是一種物理地址反向映射虛擬地址的方法。 映射 頁表用於虛擬地址到物理地址映射,其中的 頁表項記 ...
  • Mysql存儲引擎 1.MyISAM MySQL 5.0 之前的預設資料庫引擎,最為常用。擁有較高的插入,查詢速度,但不支持事務. 2.InnoDB事務型資料庫的首選引擎,支持ACID事務,支持行級鎖定, MySQL 5.5 起成為預設資料庫引擎. 3.BDB源 自 Berkeley DB,事務型數 ...
  • Index Merge特性 在MySQL 5.5之前版本中,查詢或子查詢被限制在一個表只能使用一個索引(回表查詢除外)。 假設表TB1001上C1和C2列分別有單列索引,如對下麵查詢: SELECT * FROM TB1001 WHERE C1='XXX' OR C2='XXX'; 單獨使用任一索引 ...
  • 概述: 浮點數據類型包括real型、float型、decimal型和numeric型。浮點數據類型用於存儲十進位小數。 在SQL Server 中浮點數值的數據採用上舍入(Round up)的方式進行存儲,所謂上舍入也就是,要舍入的小數部分不論其大小, 只要是一個非零的數,就要在該數字的最低有效位上 ...
  • 報錯誤The tablename is not defined (empty) 去掉表輸出中的“表分區數據” ...
  • 準確的時間是天文觀測所必需的。天文望遠鏡在特定時間內的準確指向、CCD曝光時間的控制以及不同波段觀測數據所進行的高精度同步比對等應用需要系統至少有亞毫秒的時間準確度。然而就目前來看,一般的電腦和嵌入式設備所使用的晶體振蕩器的精度為幾個或者幾十個ppm(百萬分之一秒),並且會受溫度漂移的影響,使得每... ...
  • 樹和森林 這篇博客繼續我們的《數據結構導論》課程,今天重點說說樹和森林怎麼備考自考和通過期末考試。 在開始之前,上篇博客最後其實還有一點沒有寫完,就是如何通過已知序列,恢復一棵二叉樹 看例題吧 假設一棵二叉樹的中序序列與後序序列分別為:BACDEFGH 和 BCAEDGHF 建立該二叉樹 這種題目的 ...
  • sqlserver 批量修改表的主鍵名稱,批量修改數據表的名稱 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...