千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術(shù)干貨  > 正規(guī)二叉樹和完全二叉樹有什么區(qū)別?

正規(guī)二叉樹和完全二叉樹有什么區(qū)別?

來源:千鋒教育
發(fā)布人:xqq
時間: 2023-10-11 11:03:30 1696993410

一、正規(guī)二叉樹和完全二叉樹的區(qū)別

二叉樹是每個節(jié)點非常多有兩個兒子的樹。

正規(guī)二叉樹是每個節(jié)點都有兩個或沒有兒子的二叉樹。這意味著,如果一個節(jié)點有左兒子,那么它必須有右兒子,反之亦然。

完全二叉樹是一棵二叉樹,其中除了可能深度為 h 或 h-1 的最后一層外,其余各層的節(jié)點數(shù)都達到最大個數(shù),即第 i 層非常多有 2^(i-1) 個節(jié)點(i≥1)。換句話說,如果二叉樹中除去最后一層節(jié)點為滿二叉樹,且最后一層的結(jié)點依次從左到右分布,則此二叉樹被稱為完全二叉樹。

舉個例子,下面這棵樹是一棵正規(guī)二叉樹:

? 1

?/ \

2?? 3

但是,它不是一棵完全二叉樹,因為第二層的節(jié)點數(shù)不是最大的。

延伸閱讀:

二、完全二叉樹與滿二叉樹的區(qū)別是什么

含義不同:

完全二叉樹是由滿二叉樹而引出來的。對于深度為K的,有n個結(jié)點的二叉樹,當且僅當其每一個結(jié)點都與深度為K的滿二叉樹中編號從1至n的結(jié)點一一對應(yīng)時稱之為完全二叉樹。

表示不同:

對于滿二叉樹,除最后一層無任何子節(jié)點外,每一層上的所有結(jié)點都有兩個子結(jié)點二叉樹。而完全二叉樹是效率很高的數(shù)據(jù)結(jié)構(gòu),完全二叉樹是由滿二叉樹而引出來的。

對于深度為K的,有n個結(jié)點的二叉樹,當且僅當其每一個結(jié)點都與深度為K的滿二叉樹中編號從1至n的結(jié)點一一對應(yīng)時稱之為完全二叉樹。

判斷一棵樹是否是完全二叉樹的思路

1>如果樹為空,則直接返回錯

2>如果樹不為空:層序遍歷二叉樹

2.1>如果一個結(jié)點左右孩子都不為空,則pop該節(jié)點,將其左右孩子入隊列;

2.1>如果遇到一個結(jié)點,左孩子為空,右孩子不為空,則該樹一定不是完全二叉樹;

2.2>如果遇到一個結(jié)點,左孩子不為空,右孩子為空;或者左右孩子都為空,且則該節(jié)點之后的隊列中的結(jié)點都為葉子節(jié)點,該樹才是完全二叉樹,否則就不是完全二叉樹;

聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內(nèi)將與您1V1溝通
免費領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學 138****2860 剛剛成功領(lǐng)取
王同學 131****2015 剛剛成功領(lǐng)取
張同學 133****4652 剛剛成功領(lǐng)取
李同學 135****8607 剛剛成功領(lǐng)取
楊同學 132****5667 剛剛成功領(lǐng)取
岳同學 134****6652 剛剛成功領(lǐng)取
梁同學 157****2950 剛剛成功領(lǐng)取
劉同學 189****1015 剛剛成功領(lǐng)取
張同學 155****4678 剛剛成功領(lǐng)取
鄒同學 139****2907 剛剛成功領(lǐng)取
董同學 138****2867 剛剛成功領(lǐng)取
周同學 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
軟件測試和硬件測試的區(qū)別?

一、軟件測試和硬件測試的區(qū)別1、測試工具不同軟件測試:相對來說,都是使用軟件進行,比如抓包工具Fiddler、壓力測試工具Jmeter、接口測試工具...詳情>>

2023-10-11 12:07:44
做一個App需要哪些步驟?

一、做一個App的步驟1、策劃:開發(fā)策劃是app開發(fā)的名列前茅步,它是確定最終的app開發(fā)方案和規(guī)劃的必要步驟,開發(fā)策劃的目的是把app的構(gòu)思從理...詳情>>

2023-10-11 12:03:04
c語言鏈表初始化是什么意思?

一、c語言鏈表初始化是什么意思C語言中鏈表是一種常用的數(shù)據(jù)結(jié)構(gòu),用于存儲數(shù)據(jù)元素并實現(xiàn)各種算法和操作。鏈表通常由若干個節(jié)點(Node)組成,...詳情>>

2023-10-11 11:54:47
為什么sql數(shù)據(jù)庫用B樹索引,而不是用其他樹型數(shù)據(jù)結(jié)構(gòu)?

一、sql數(shù)據(jù)庫用B樹索引,而不是用其他樹型數(shù)據(jù)結(jié)構(gòu)的原因SQL數(shù)據(jù)庫中使用B樹索引的主要原因是其高效的查詢和插入性能,以及對于高并發(fā)的支持。...詳情>>

2023-10-11 11:43:20
vector容器原理是什么?

一、vector容器原理vector容器分配的是一塊連續(xù)的內(nèi)存空間,每次容器的增長,并不是在原有連續(xù)的內(nèi)存空間后再進行簡單的疊加,而是重新申請一塊...詳情>>

2023-10-11 11:02:27