『壹』 二叉樹_順序存儲
滿二叉樹 (Full Binary Tree)
所有分支結點都有存在左子樹和右子樹,並且所有葉子結點都在同一層上。
完全二叉樹 (Complete Binary Tree)
如果一棵具有n個結點的二叉樹與滿二叉樹的前n個結點的結構相同,則稱這棵二叉樹為完全二叉樹。
重要性質 :
對於一棵有n個結點的 完全二叉樹 的結點按照從上至下和從左至右的順序對所有結點從零開始到 n-1 進行順序編號,則對於序號為i的結點(0≤i≤n),有:
(1)如果 i=0,則結點i是二叉樹的根;如果i>0,則其 雙親 是結點 (i-1)/2 (整除)。
(2)如果2i+1≥n,則結點i無左孩子;否則,其 左孩子 是結點 2i+1 。
(3)如果2i+2≥n,則結點i無右孩子;否則,其 右孩子 是結點 2i+2 。
根據上面兩點,得到二叉樹順序存儲的實現:
定義:
獲取雙親節點下標:
左子節點下標:
右子節點下標:
主函數測試:
總結:
1、對於完全二叉樹或接近於完全的二叉樹,用順序存儲可以省空間簡化操作;否則,都不適宜用順序存儲。
2、順序存儲結構通病:必須預先給出數組的存儲空間大小MaxSize。
『貳』 二叉樹順序存儲
順序存儲的話,就是存儲在數組中,數組的下標就是二叉樹的結點位置(層次結構),比如結點A,在數組中就是位置0,B就是1,C就是2....,以此類推,所以第i個結點的在數組中的位置就是i(i從0開始),i的兩個孩子結點在數組中的位置是2i+1和2i+2
『叄』 順序存儲是二叉樹常用的存儲結構嗎
二叉樹的存儲結構
二叉樹是非線性結構,即每個數據結點至多隻有一個前驅,但可以有多個後繼。它可採用順序存儲結構和鏈式存儲結構。
1.順序存儲結構
二叉樹的順序存儲,就是用一組連續的存儲單元存放二叉樹中的結點。因此,必須把二叉樹的所有結點安排成為一個恰當的序列,結點在這個序列中的相互位置能反映出結點之間的邏輯關系,用編號的方法從樹根起,自上層至下層,每層自左至右地給所有結點編號,缺點是有可能對存儲空間造成極大的浪費,在最壞的情況下,一個深度為k且只有k個結點的右單支樹需要2k-1個結點存儲空間。依據二叉樹的性質,完全二叉樹和滿二叉樹採用順序存儲比較合適,樹中結點的序號可以唯一地反映出結點之間的邏輯關系,這樣既能夠最大可能地節省存儲空間,又可以利用數組元素的下標值確定結點在二叉樹中的位置,以及結點之間的關系。圖5-5(a)是一棵完全二叉樹,圖5-5(b)給出的圖5-5(a)所示的完全二叉樹的順序存儲結構。
(a) 一棵完全二叉樹 (b) 順序存儲結構
圖5-5 完全二叉樹的順序存儲示意圖
對於一般的二叉樹,如果仍按從上至下和從左到右的順序將樹中的結點順序存儲在一維數組中,則數組元素下標之間的關系不能夠反映二叉樹中結點之間的邏輯關系,只有增添一些並不存在的空結點,使之成為一棵完全二叉樹的形式,然後再用一維數組順序存儲。如圖5-6給出了一棵一般二叉樹改造後的完全二叉樹形態和其順序存儲狀態示意圖。顯然,這種存儲對於需增加許多空結點才能將一棵二叉樹改造成為一棵完全二叉樹的存儲時,會造成空間的大量浪費,不宜用順序存儲結構。最壞的情況是右單支樹,如圖5-7 所示,一棵深度為k的右單支樹,只有k個結點,卻需分配2k-1個存儲單元。
(a) 一棵二叉樹 (b) 改造後的完全二叉樹
(c) 改造後完全二叉樹順序存儲狀態
圖5-6 一般二叉樹及其順序存儲示意圖
(a) 一棵右單支二叉樹 (b) 改造後的右單支樹對應的完全二叉樹
(c) 單支樹改造後完全二叉樹的順序存儲狀態
圖5-7 右單支二叉樹及其順序存儲示意圖
結構5-1二叉樹的順序存儲
#define Maxsize 100 //假設一維數組最多存放100個元素
typedef char Datatype; //假設二叉樹元素的數據類型為字元
typedef struct
{ Datatype bt[Maxsize];
int btnum;
}Btseq;
2.鏈式存儲結構
二叉樹的鏈式存儲結構是指,用鏈表來表示一棵二叉樹,即用鏈來指示元素的邏輯關系。
通常的方法是鏈表中每個結點由三個域組成,數據域和左右指針域,左右指針分別用來給出該結點左孩子和右孩子所在的鏈結點的存儲地址。其結點結構為:
其中,data域存放某結點的數據信息;lchild與rchild分別存放指向左孩子和右孩子的指針,當左孩子或右孩子不存在時,相應指針域值為空(用符號∧或NULL表示)。利用這樣的結點結構表示的二叉樹的鏈式存儲結構被稱為二叉鏈表,如圖5-8所示。
(a) 一棵二叉樹 (b) 二叉鏈表存儲結構
圖5-8 二叉樹的二叉鏈表表示示意圖
為了方便訪問某結點的雙親,還可以給鏈表結點增加一個雙親欄位parent,用來指向其雙親結點。每個結點由四個域組成,其結點結構為:
這種存儲結構既便於查找孩子結點,又便於查找雙親結點;但是,相對於二叉鏈表存儲結構而言,它增加了空間開銷。利用這樣的結點結構表示的二叉樹的鏈式存儲結構被稱為三叉鏈表。
圖5-9給出了圖5-8 (a)所示的一棵二叉樹的三叉鏈表表示。
圖5-9二叉樹的三叉鏈表表示示意圖
盡管在二叉鏈表中無法由結點直接找到其雙親,但由於二叉鏈表結構靈活,操作方便,對於一般情況的二叉樹,甚至比順序存儲結構還節省空間。因此,二叉鏈表是最常用的二叉樹存儲方式。
結構5-2二叉樹的鏈式存儲
#define datatype char //定義二叉樹元素的數據類型為字元
typedef struct node //定義結點由數據域,左右指針組成
{ Datatype data;
struct node *lchild,*rchild;
}Bitree;
『肆』 二叉樹的順序存儲結構數據A B C D E
二叉樹結構鏈式圖:
A
/
\
B
C
/
\
D
E
前序遍歷:(根,左,右):
A
->
B -> D -> E -> C中序遍歷:(左,根,右):
D -> B -> E -> A -> C後序遍歷:(左,右,根):
D -> E -> B -> C -> A
前序
中序
後序
遍歷,主要是以根節點做為參考點,進行遍歷。(根,左,右)
遍歷順序中
『根』
在第一個,所以叫前序遍歷。(左,根,右) 遍歷順序中
『根』
在第二個,所以叫中序遍歷。(左,右,根) 遍歷順序中
『根』
在第三個,所以叫後序遍歷。
『伍』 1、二叉樹採用順序存儲結構進行存儲,如圖所示
答案如下:
『陸』 什麼是二叉樹的順序存儲
二叉樹的順序存儲是將二叉樹的所有結點,按照一定的次序,存儲到一片連續的存儲單元中
二叉樹的順序存儲必須將結點排成一個適當的線性序列,使得結點在這個序列中的相應位置能反映出結點之間的邏輯關系。這種結構特別適用於近似滿二叉樹。
在一棵具有n個結點的近似滿二叉樹中,當從樹根起,自上層到下層,逐層從左到右給所有結點編號時,就能得到一個足以反映整個二叉樹結構的線性序列。其中每個結點的編號就作為結點。
(6)二叉樹按順序存儲擴展閱讀:
二叉樹的性質:
1、二叉樹第i層上的結點數目最多為2{i-1}(i≥1)。
2、深度為k的二叉樹至多有2{k}-1個結點(k≥1)。
3、包含n個結點的二叉樹的高度至少為log2(n+1)。
4、在任意一棵二叉樹中,若終端結點的個數為n0,度為2的結點數為n2,則n0=n2+1。
參考資料來源:網路-二叉樹
『柒』 完全二叉樹為什麼最適合順序存儲結構
順序存儲充分利用滿二叉樹的特性,即每層的節點數分別為1、2、4、8等等2i+1,一個深度為i的二叉樹最多隻能包含2i-1個節點,因此只要定義一個長度為2i-1的數組即可存儲這顆二叉樹。
對於普通的不是滿二叉樹的,那些空出來的節點對應的數組元素留空即可,因此順序存儲會造成一定的空間浪費。如果是完全二叉樹,就不會有空間浪費的情況;若是只有右子樹,那麼會造成相當大的浪費。
二叉樹演算法思路:
1、如果樹為空,則直接返回錯。
2、如果樹不為空:層序遍歷二叉樹。
3、如果一個結點左右孩子都不為空,則pop該節點,將其左右孩子入隊列。
4、如果遇到一個結點,左孩子為空,右孩子不為空,則該樹一定不是完全二叉樹。
5、如果遇到一個結點,左孩子不為空,右孩子為空;或者左右孩子都為空;則該節點之後的隊列中的結點都為葉子節點;該樹才是完全二叉樹,否則就不是完全二叉樹。
『捌』 完全二叉樹的存儲結構通常採用順序存儲結構()
正確。
一棵深度為k的有n個結點的二叉樹,對樹中的結點按從上至下、從左到右的順序進行編號,如果編號為i(1≤i≤n)的結點與滿二叉樹中編號為i的結點在二叉樹中的位置相同,則這棵二叉樹稱為完全二叉樹。
如果對滿二叉樹的結點進行編號, 約定編號從根結點起, 自上而下, 自左而右。則深度為k的, 有n個結點的二叉樹, 當且僅當其每一個結點都與深度為k的滿二叉樹中編號從1至n的結點一一對應時, 稱之為完全二叉樹。
(8)二叉樹按順序存儲擴展閱讀:
判斷一棵樹是否是完全二叉樹的思路
1、如果樹為空,則直接返回錯。
2、如果樹不為空:層序遍歷二叉樹。
如果一個結點左右孩子都不為空,則pop該節點,將其左右孩子入隊列。
如果遇到一個結點,左孩子為空,右孩子不為空,則該樹一定不是完全二叉樹。
如果遇到一個結點,左孩子不為空,右孩子為空;或者左右孩子都為空;則該節點之後的隊列中的結點都為葉子節點;該樹才是完全二叉樹,否則就不是完全二叉樹。