數據結構課上筆記11

滿二叉樹 (Full binary tree)

除最后一層無任何子節點外,每一層上的所有結點都有兩個子結點二叉樹。

國內教程定義:一個二叉樹,如果每一個層的結點數都達到最大值,則這個二叉樹就是滿二叉樹。也就是說,如果一個二叉樹的層數為K,且結點總數是(2^k) -1 ,則它就是滿二叉樹。

國外(國際)定義:a binary tree T is full if each node is either a leaf or possesses exactly two childnodes.

大意為:如果一棵二叉樹的結點要么是葉子結點,要么它有兩個子結點,這樣的樹就是滿二叉樹。(一棵滿二叉樹的每一個結點要么是葉子結點,要么它有兩個子結點,但是反過來不成立,因為完全二叉樹也滿足這個要求,但不是滿二叉樹)

從圖形形態上看,滿二叉樹外觀上是一個三角形。

圖一

從數學上看,滿二叉樹的各個層的結點數形成一個首項為1,公比為2的等比數列。

因此由等比數列的公式,滿二叉樹滿足如下性質。

1、一個層數為k 的滿二叉樹總結點數為:

??。因此滿二叉樹的結點樹一定是奇數個。

2、第i層上的結點數為:?

3、一個層數為k的滿二叉樹的葉子結點個數(也就是最后一層):?

?

完全二叉樹

?

完全二叉樹是效率很高的數據結構,完全二叉樹是由滿二叉樹而引出來的。對于深度為K的,有n個結點的二叉樹,當且僅當其每一個結點都與深度為K的滿二叉樹中編號從1至n的結點一一對應時稱之為完全二叉樹。

可以根據公式進行推導,假設n0是度為0的結點總數(即葉子結點數),n1是度為1的結點總數,n2是度為2的結點總數,則 :

①n= n0+n1+n2?(其中n為完全二叉樹的結點總數);又因為一個度為2的結點會有2個子結點,一個度為1的結點會有1個子結點,除根結點外其他結點都有父結點,

②n= 1+n1+2*n2?;由①、②兩式把n2消去得:n= 2*n0+n1-1,由于完全二叉樹中度為1的結點數只有兩種可能0或1,由此得到n0=n/2 或 n0=(n+1)/2。

簡便來算,就是 n0=n/2,其中n為奇數時(n1=0)向上取整;n為偶數時(n1=1)。可根據完全二叉樹的結點總數計算出葉子結點數。

?

重點:出于簡便起見,完全二叉樹通常采用數組而不是鏈表存儲

?

對于tree[i]有如下特點:

(1)若i為奇數且i>1,那么tree的左兄弟為tree[i-1];

(2)若i為偶數且i<n,那么tree的右兄弟為tree[i+1];

(3)若i>1,tree的父親節點為tree[i?div?2];

(4)若2*i<=n,那么tree的左孩子為tree[2*i];若2*i+1<=n,那么tree的右孩子為tree[2*i+1];

(5)若i>n div 2,那么tree[i]為葉子結點(對應于(3));

(6)若i<(n-1) div 2.那么tree[i]必有兩個孩子(對應于(4))。

(7)滿二叉樹一定是完全二叉樹,完全二叉樹不一定是滿二叉樹。

完全二叉樹第i層至多有2^(i-1)個節點,共i層的完全二叉樹最多有2^i-1個節點。

特點:

1)只允許最后一層有空缺結點且空缺在右邊,即葉子結點只能在層次最大的兩層上出現;

2)對任一結點,如果其右子樹的深度為j,則其左子樹的深度必為j或j+1。 即度為1的點只有1個或0個

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

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

相關文章

數據結構和算法(01)--- 算法復雜度

文章目錄算法時間復雜度算法時間復雜度 要判斷算法的好壞&#xff0c;可以從時間方面進行分析。算法運行的越快&#xff0c;所用的時間越短則算法越好。但是同一個算法在不同的平臺上的運行時間不同。那么又該如何進行評判呢&#xff1f;我們采用時間復雜度進行衡量。 1.算法時…

數據結構課上筆記12

二叉樹的存儲結構 順序存儲結構 完全二叉樹&#xff1a;用一組地址連續的 存儲單元依次自上而下、自左至右存 儲結點元素&#xff0c;即將編號為 i 的結點元 素存儲在一維數組中下標為 i –1 的分量中。 一般二叉樹&#xff1a;將其每個結點與完 全二叉樹上的結點相對照&…

kaggle(01)-泰坦尼克號問題

經典又兼具備趣味性的Kaggle案例泰坦尼克號問題 大家都熟悉的『Jack and Rose』的故事&#xff0c;豪華游艇倒了&#xff0c;大家都驚恐逃生&#xff0c;可是救生艇的數量有限&#xff0c;無法人人都有&#xff0c;副船長發話了『lady and kid first&#xff01;』&#xff0c…

數據結構課上筆記13

樹存儲結構 父節點表示法 數據域&#xff1a;存放結點本身信息。 雙親域&#xff1a;指示本結點的雙親結點在數組中的位置。 對應的樹&#xff1a; /* 樹節點的定義 */ #define MAX_TREE_SIZE 100typedef struct{TElemType data;int parent; /* 父節點位置域 */ } PTNode;type…

數據結構課上筆記14

圖是一種&#xff1a; 數據元素間存在多對多關系的數據結構 加上一組基本操作構成的抽象數據類型。 圖 (Graph) 是一種復雜的非線性數據結構&#xff0c;由頂點集合及頂點間的關系&#xff08;也稱弧或邊&#xff09;集合組成。可以表示為&#xff1a; G&#xff1d;(V, V…

kaggle(03)-自行車租賃預測問題(基礎版)

文章目錄問題描述&#xff1a;問題解決分析問題&#xff1a;解決問題第一步&#xff1a;讀取原始數據第二步&#xff1a;觀察原始數據第三步&#xff1a;原始數據的可視化第四步&#xff1a;數據的預處理時間屬性的分解第五步&#xff1a;數據的特征提取特征生成特征選擇第六步…

二叉樹序列化/反序列化

二叉樹被記錄成文件的過程&#xff0c;為二叉樹的序列化 通過文件重新建立原來的二叉樹的過程&#xff0c;為二叉樹的反序列化 設計方案并實現。 &#xff08;已知結點類型為32位整型&#xff09; 思路&#xff1a;先序遍歷實現。 因為要寫入文件&#xff0c;我們要把二叉樹…

機器學習總結(17)-XGBoost

文章目錄lecture17&#xff1a;XGBoost(eXtreme Gradient Boosting)目錄1. XGBoost的基本信息2. XGBoost與GBDT的異同點3. XGBoost的原理3.1定義樹的復雜度3.2 分裂節點3.3 自定義損失函數4. XGBoost的使用lecture17&#xff1a;XGBoost(eXtreme Gradient Boosting) 目錄 1. …

C++基礎學習(01)--(介紹,環境配置,基本語法,注釋)

文章目錄目錄一. c介紹二. c開發環境到的配置三. c基本語法四. c注釋目錄 一. c介紹 C 是一種靜態類型的、編譯式的、通用的、大小寫敏感的、不規則的編程語言&#xff0c;支持過程化編程、面向對象編程和泛型編程。 C 被認為是一種中級語言&#xff0c;它綜合了高級語言和低…

《Head First設計模式》讀書筆記_第一章

策略模式 例&#xff1a;設計一個模擬鴨子游戲&#xff0c;游戲中有各種鴨子&#xff0c;一邊戲水一邊嘎嘎叫。 所以學習設計模式前&#xff0c;我們最先想到的就是設置一個超類&#xff0c;并讓其他子類去繼承這個類&#xff0c;UML圖如下&#xff1a; * * 但是&#xff0…

根據數組建立平衡二叉搜索樹

它是一 棵空樹或它的左右兩個子樹的高度差的絕對值不超過1&#xff0c;并且左右兩個子樹都是一棵平衡二叉&#xff08;搜索&#xff09;樹。 二分&#xff1a;用有序數組中中間的數生成搜索二叉樹的頭節點&#xff0c;然后對數組的左右部分分別生成左右子樹即可&#xff08;重復…

C++基礎學習(02)--(數據類型,變量類型,變量作用域,常量,修飾符類型)

文章目錄目錄一. 數據類型C 中的數據類型typedefenumeration枚舉類型c中變量類型二.變量作用域三.常量四.修飾符類型目錄 一. 數據類型 C 中的數據類型 使用編程語言進行編程時&#xff0c;需要用到各種變量來存儲各種信息。變量保留的是它所存儲的值的內存位置。這意味著&a…

commons-lang常用方法

maven引入 <dependency><groupId>org.apache.commons</groupId><artifactId>commons-lang3</artifactId><version>3.9</version></dependency> 跟java.lang這個包的作用類似&#xff0c;Commons Lang這一組API也是提供一些基…

c++基礎學習(03)--(存儲類,運算符,循環,判斷)

文章目錄目錄一.存儲類二.運算符三.循環whilefor四.判斷目錄 一.存儲類 可見static存儲類修飾之后&#xff0c;i的值沒有從頭開始&#xff0c;而是從上一次的結果中保留下來 #include <iostream>using namespace std; class Data { public:Data(){}~Data(){}void show()…

皇后問題

八皇后問題是一個以國際象棋為背景的問題&#xff1a;如何能夠在 88 的國際象棋棋盤上放置八個皇后&#xff0c;使得任何一個皇后都無法直接吃掉其他的皇后&#xff1f;為了達到此目的&#xff0c;任兩個皇后都不能處于同一條橫行、縱行或斜線上。八皇后問題可以推廣為更一般的…

c++基礎學習(04)--(函數、數字、數組、字符串)

文章目錄目錄1.函數2.數字3.字符串4.數組目錄 1.函數 #include <iostream> #include <limits>using namespace std;void swap(int *x , int *y);int main(){int a 100 , b200;cout<<"交換前:"<<"a is :"<<a<<"…

【精品計劃0】藍橋杯 摔手機

原題描述&#xff1a; x星球的居民脾氣不太好&#xff0c;但好在他們生氣的時候唯一的異常舉動是&#xff1a;摔手機。 各大廠商也就紛紛推出各種耐摔型手機。x星球的質監局規定了手機必須經過耐摔測試&#xff0c;并且評定出一個耐摔指數來&#xff0c;之后才允許上市流通。 …

數據結構課上筆記15

圖的存儲 多重鏈表&#xff1a;完全模擬圖的樣子&#xff0c;每個節點內的指針都指向該指向的節點。 節點結構內指針數為度 缺點&#xff1a;浪費空間、不容易操作 數組表示法&#xff08;鄰接矩陣表示法&#xff09; 可用兩個數組存儲。其中一個 一維數組存儲數據元素&#…

c++基礎學習(05)--(指針,引用)

文章目錄目錄1.指針2.引用目錄 1.指針 #include <iostream>using namespace std;int main () {int var1;char var2[10];cout << "var1 變量的地址&#xff1a; ";cout << &var1 << endl;cout << "var2 變量的地址&#xff…

由旅行商問題認識何為狀態壓縮

動態規劃 動態規劃(dynamic programming)是運籌學的一個分支&#xff0c;是求解決策過程(decision process)最優化的數學方法。20世紀50年代初美國數學家R.E.Bellman等人在研究多階段決策過程(multistep decision process)的優化問題時&#xff0c;提出了著名的最優化原理(pri…