10.二叉樹(shù)簡(jiǎn)介及先序砂轻、中序拱礁、后序


大綱:

  1. 二叉樹(shù)介紹
  2. 先序/中序/后序 Preorder/inorder/postorder
  3. 分治算法 Divide & Conquer
  4. 二叉樹(shù)的寬度優(yōu)先遍歷
  5. 二叉樹(shù)搜索樹(shù)

翻轉(zhuǎn)二叉樹(shù)

Homebrew作者M(jìn)ark Howell面試被Google拒守伸,因?yàn)椴粫?huì)翻轉(zhuǎn)二叉樹(shù)

(額……這也真夠慘的……)

翻轉(zhuǎn)二叉樹(shù)
翻轉(zhuǎn)二叉樹(shù)

原題地址

解題思路:堆二叉樹(shù)左右鏈表進(jìn)行轉(zhuǎn)換绎秒,是否有似曾相識(shí)的感覺(jué)?交換兩個(gè)值的swap你一定寫(xiě)過(guò)吧尼摹,對(duì)的见芹,就是它剂娄,我們將二叉樹(shù)的左右假想為兩個(gè)“特殊的值”,然后定義一個(gè)tmp用來(lái)儲(chǔ)存一方交換值玄呛,然后交換他們即可阅懦,這里提到的“特殊的值”便是遞歸調(diào)用。

示例代碼:


/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
 * };
 */

class Solution {
public:
    TreeNode* invertTree(TreeNode* root) {
        if (root == NULL)
            return NULL;

        TreeNode* tmpNode = root->left;
        root->left = invertTree(root->right);
        root->right = invertTree(tmpNode);

        return root;
    }   
}


二叉樹(shù)

二叉樹(shù)徘铝,是指對(duì)于樹(shù)中的每個(gè)節(jié)點(diǎn)而言耳胎,至多有左右兩個(gè)子節(jié)點(diǎn),即任意節(jié)點(diǎn)的度小于等于2


二叉樹(shù)
二叉樹(shù)

概念

  • 高度:從根節(jié)點(diǎn)到某個(gè)節(jié)點(diǎn)的路徑長(zhǎng)度稱為該節(jié)點(diǎn)的層數(shù)(level)惕它,根節(jié)點(diǎn)為第0層怕午,非根節(jié)點(diǎn)的層數(shù)是其父節(jié)點(diǎn)的層數(shù)加1。樹(shù)的高度定義為該樹(shù)中層數(shù)最大的葉節(jié)點(diǎn)的層數(shù)加1淹魄,即相當(dāng)于于從根節(jié)點(diǎn)到葉節(jié)點(diǎn)的最長(zhǎng)路徑加1郁惜。
  • 滿二叉樹(shù)(full binary tree):如果一棵二叉樹(shù)的任何結(jié)點(diǎn),或者是葉節(jié)點(diǎn)揭北,或者左右子樹(shù)都存在扳炬,則這棵二叉樹(shù)稱作滿二叉樹(shù)。
  • 完全二叉樹(shù)(complete binary tree):如果一棵二叉樹(shù)最多只有最下面的兩層節(jié)點(diǎn)度數(shù)可以小于2搔体,并且最下面一層的節(jié)點(diǎn)都集中在該層最左邊的連續(xù)位置上,則此二叉樹(shù)稱作完全二叉樹(shù)半醉。

Binary Tree DFS Traversal

Binary Tree Traversal

二叉樹(shù)遍歷
二叉樹(shù)遍歷

二叉樹(shù)遍歷中說(shuō)的前中后序是以根節(jié)點(diǎn)為基準(zhǔn)的疚俱,根節(jié)點(diǎn)在前則為前序遍歷,在最后則為后序遍歷缩多,否則為中序遍歷

DFS代碼


//前序遍歷
void preOrderTraversal(TreeNode *root) {
    if (!root) {
        return;
    }

    visit(root);

    preOrderTraversal(root->left);
    preOrderTraversal(root->right);
}

//中序遍歷
void inOrderTraversal(TreeNode *root) {
    if (!root) {
        return;
    }
    
    inOrderTraversal(root->right);
    visit(root);
    inOrderTraversal(root->left);
}

//后序遍歷
void postOrderTraversal(TreeNode *root) {
    if (!root) {
        return;
    }

    postOrderTraversal(root->left);
    postOrderTraversal(root->right);
    visit(root);
}

Traverse Iteration

Stack: Preorder

示例代碼:


public static void preOrder(Node root){
    LinkedList<Node> stack = new LinkedList<Node>();
    Node pointer = root;
    stack.push(root);
    while(!stack.isEmpty()) {
        pointer = stack.pop();
        System.out.print(pointer.data+", ");
        if(pointer.rightChild != NULL)
            stack.push(pointer.rightChild);
        if(pointer.leftChild != NULL)
            stack.push(pointer.leftChild);
    }
    System.out.prinln();
}

博文入口

Find Next in Binary Tree

In-order traverse a binary tree with parent links, find the next node to visit given a specific node.

中序查找
中序查找

Followup: without parent link?

問(wèn)題描述:一個(gè)按照中序遍歷排列的二叉樹(shù)呆奕,找到給定節(jié)點(diǎn)的下一個(gè)節(jié)點(diǎn)

代碼示例:

遍歷順序均為“左、中衬吆、右”順序

當(dāng)我們不知道根節(jié)點(diǎn)時(shí)



TreeNode *leftMostNode(TreeNode *node) {
    if (!node) {
        return NULL;
    }
    while (node->left) {
        node = node->left;
    }
    return node;
}

bool isLeftChild(TreeNode *node, TreeNode *parent) {
    return (parent->left == node);
}

TreeNode *inOrderSuccessor(TreeNode *node) {
    
    //當(dāng)給定節(jié)點(diǎn)為空時(shí)返回NULL
    if (!node) {
        return NULL;
    }

    //當(dāng)給定節(jié)點(diǎn)的右子樹(shù)存在時(shí)梁钾,返回右子樹(shù)的左子樹(shù)(如果左子樹(shù)存在的話,否則返回給定節(jié)點(diǎn)的右子樹(shù))
    if (node->right) {
        return leftMostNode(node->right);
    }

    //如果是給定節(jié)點(diǎn)在根左子樹(shù)的末尾逊抡,如上圖中保存14的節(jié)點(diǎn)姆泻,那么就遍歷返回到根節(jié)點(diǎn)
    TreeNode *parent = node->parent;
    while (parent && !isLeftChild(node, parent)) {
        node = parent;
        parent = node->parent;
    }
    return parent;
}

當(dāng)我們知道根節(jié)點(diǎn)時(shí)


TreeNode *inOrderSuccessor(TreeNode *node, TreeNode *root)
{
    if (!node) {
        return NULL;
    }

    //如果存在右子樹(shù),返回右子樹(shù)的左子樹(shù)
    if (node->right) {
        return leftMostNode(node->right);
    }

    //當(dāng)root的值小于給定node值冒嫡,但是下次開(kāi)始大于node值時(shí)拇勃,
    //successor成功獲取我們要尋找的下一個(gè)節(jié)點(diǎn)的值
    TreeNode *successor = NULL;
    while (root) {
        if (root->val > node->val) {
            successor = root;
            root = root->left;
        } else {
            root = root->right;
        }
    }
    return successor;
}


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市孝凌,隨后出現(xiàn)的幾起案子方咆,更是在濱河造成了極大的恐慌,老刑警劉巖蟀架,帶你破解...
    沈念sama閱讀 218,682評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件瓣赂,死亡現(xiàn)場(chǎng)離奇詭異榆骚,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)煌集,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,277評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門寨躁,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人牙勘,你說(shuō)我怎么就攤上這事职恳。” “怎么了方面?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,083評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵放钦,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我恭金,道長(zhǎng)操禀,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,763評(píng)論 1 295
  • 正文 為了忘掉前任横腿,我火速辦了婚禮颓屑,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘耿焊。我一直安慰自己揪惦,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,785評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布罗侯。 她就那樣靜靜地躺著器腋,像睡著了一般。 火紅的嫁衣襯著肌膚如雪钩杰。 梳的紋絲不亂的頭發(fā)上纫塌,一...
    開(kāi)封第一講書(shū)人閱讀 51,624評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音讲弄,去河邊找鬼措左。 笑死,一個(gè)胖子當(dāng)著我的面吹牛避除,可吹牛的內(nèi)容都是我干的怎披。 我是一名探鬼主播,決...
    沈念sama閱讀 40,358評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼驹饺,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼钳枕!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起赏壹,我...
    開(kāi)封第一講書(shū)人閱讀 39,261評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤鱼炒,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后蝌借,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體昔瞧,經(jīng)...
    沈念sama閱讀 45,722評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡指蚁,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了自晰。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片凝化。...
    茶點(diǎn)故事閱讀 40,030評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖酬荞,靈堂內(nèi)的尸體忽然破棺而出搓劫,到底是詐尸還是另有隱情,我是刑警寧澤混巧,帶...
    沈念sama閱讀 35,737評(píng)論 5 346
  • 正文 年R本政府宣布枪向,位于F島的核電站,受9級(jí)特大地震影響咧党,放射性物質(zhì)發(fā)生泄漏秘蛔。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,360評(píng)論 3 330
  • 文/蒙蒙 一傍衡、第九天 我趴在偏房一處隱蔽的房頂上張望深员。 院中可真熱鬧,春花似錦蛙埂、人聲如沸倦畅。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,941評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)滔迈。三九已至,卻和暖如春被辑,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背敬惦。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,057評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工盼理, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人俄删。 一個(gè)月前我還...
    沈念sama閱讀 48,237評(píng)論 3 371
  • 正文 我出身青樓宏怔,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親畴椰。 傳聞我的和親對(duì)象是個(gè)殘疾皇子臊诊,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,976評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容