二叉樹基礎(chǔ)上

  • 節(jié)點(diǎn)的高度=節(jié)點(diǎn)到葉子節(jié)點(diǎn)的最大路徑(邊數(shù))
  • 節(jié)點(diǎn)的深度=根節(jié)點(diǎn)到這個(gè)節(jié)點(diǎn)所經(jīng)歷的邊的個(gè)數(shù)
  • 節(jié)點(diǎn)的層數(shù)=節(jié)點(diǎn)的深度+1
  • 樹的高度=根節(jié)點(diǎn)的高度

二叉樹

二叉樹笙纤,顧名思義,每個(gè)節(jié)點(diǎn)最多有兩個(gè)“叉”了讨,也就是兩個(gè)子節(jié)點(diǎn),分別是左子節(jié)點(diǎn)和右子節(jié)點(diǎn)。

滿二叉樹

葉子節(jié)點(diǎn)全都在最底層,除了葉子節(jié)點(diǎn)之外见妒,每個(gè)節(jié)點(diǎn)都有左右兩個(gè)子節(jié)點(diǎn),這種二叉樹就叫作滿二叉樹甸陌。

完全二叉樹

葉子節(jié)點(diǎn)都在最底下兩層须揣,最后一層的葉子節(jié)點(diǎn)都靠左排列,并且除了最后一層钱豁,其他層的節(jié)點(diǎn)個(gè)數(shù)都要達(dá)到最大耻卡,這種二叉樹叫作完全二叉樹。

如何表達(dá)(或者存儲(chǔ))一顆二叉樹寥院?

  • 一種是基于指針或者引用的二叉鏈?zhǔn)酱鎯?chǔ)法
  • 一種是基于數(shù)組的順序存儲(chǔ)法

二叉樹的遍歷

  • 前序遍歷是指劲赠,對(duì)于樹中的任意節(jié)點(diǎn)來說涛目,先打印這個(gè)節(jié)點(diǎn)秸谢,然后再再打印它的左子樹,最后打印它的右子樹霹肝。
  • 中序遍歷是指估蹄,對(duì)于樹中的任意節(jié)點(diǎn)來說,先打印它的左子樹沫换,然后再打印它本身臭蚁,最后打印它的右子樹。
  • 后序遍歷是指,對(duì)于樹中的任意節(jié)點(diǎn)來說垮兑,先打印它的左子樹冷尉,然后再打印它的右子樹,最后打印這個(gè)節(jié)點(diǎn)本身系枪。

偽代碼

前序遍歷的遞推公式:
preOrder(r) = print r->preOrder(r->left)->preOrder(r->right)

中序遍歷的遞推公式:
inOrder(r) = inOrder(r->left)->print r->inOrder(r->right)

后序遍歷的遞推公式:
postOrder(r) = postOrder(r->left)->postOrder(r->right)->print r

代碼

void preOrder(Node* root) {
  if (root == null) return;
  print root // 此處為偽代碼雀哨,表示打印 root 節(jié)點(diǎn)
  preOrder(root->left);
  preOrder(root->right);
}

void inOrder(Node* root) {
  if (root == null) return;
  inOrder(root->left);
  print root // 此處為偽代碼,表示打印 root 節(jié)點(diǎn)
  inOrder(root->right);
}

void postOrder(Node* root) {
  if (root == null) return;
  postOrder(root->left);
  postOrder(root->right);
  print root // 此處為偽代碼私爷,表示打印 root 節(jié)點(diǎn)
}

時(shí)間復(fù)雜度:O(n)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末雾棺,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子衬浑,更是在濱河造成了極大的恐慌捌浩,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,509評(píng)論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件工秩,死亡現(xiàn)場(chǎng)離奇詭異尸饺,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)助币,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,806評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門侵佃,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人奠支,你說我怎么就攤上這事馋辈。” “怎么了倍谜?”我有些...
    開封第一講書人閱讀 163,875評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵迈螟,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我尔崔,道長(zhǎng)答毫,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,441評(píng)論 1 293
  • 正文 為了忘掉前任季春,我火速辦了婚禮洗搂,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘载弄。我一直安慰自己耘拇,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,488評(píng)論 6 392
  • 文/花漫 我一把揭開白布宇攻。 她就那樣靜靜地躺著惫叛,像睡著了一般。 火紅的嫁衣襯著肌膚如雪逞刷。 梳的紋絲不亂的頭發(fā)上嘉涌,一...
    開封第一講書人閱讀 51,365評(píng)論 1 302
  • 那天妻熊,我揣著相機(jī)與錄音,去河邊找鬼仑最。 笑死扔役,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的警医。 我是一名探鬼主播厅目,決...
    沈念sama閱讀 40,190評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼法严!你這毒婦竟也來了损敷?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,062評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤深啤,失蹤者是張志新(化名)和其女友劉穎拗馒,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體溯街,經(jīng)...
    沈念sama閱讀 45,500評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡诱桂,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,706評(píng)論 3 335
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了呈昔。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片挥等。...
    茶點(diǎn)故事閱讀 39,834評(píng)論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖堤尾,靈堂內(nèi)的尸體忽然破棺而出肝劲,到底是詐尸還是另有隱情,我是刑警寧澤郭宝,帶...
    沈念sama閱讀 35,559評(píng)論 5 345
  • 正文 年R本政府宣布辞槐,位于F島的核電站,受9級(jí)特大地震影響粘室,放射性物質(zhì)發(fā)生泄漏榄檬。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,167評(píng)論 3 328
  • 文/蒙蒙 一衔统、第九天 我趴在偏房一處隱蔽的房頂上張望鹿榜。 院中可真熱鬧,春花似錦锦爵、人聲如沸舱殿。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,779評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽怀薛。三九已至刺彩,卻和暖如春迷郑,著一層夾襖步出監(jiān)牢的瞬間枝恋,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,912評(píng)論 1 269
  • 我被黑心中介騙來泰國打工嗡害, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留焚碌,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,958評(píng)論 2 370
  • 正文 我出身青樓霸妹,卻偏偏與公主長(zhǎng)得像十电,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子叹螟,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,779評(píng)論 2 354