[LeetCode]94. Binary Tree Inorder Traversal

Given a binary tree, return the inorder traversal of its nodes' values.

For example:
Given binary tree [1,null,2,3],

  1 
   \ 
    2
   / 
  3

return [1,3,2].

Note: Recursive solution is trivial, could you do it iteratively?

中序遍歷

中序遍歷是首先遍歷左子樹(shù)铣墨,然后訪問(wèn)根結(jié)點(diǎn)侈百,最后遍歷右子樹(shù)追他。在遍歷左、右子樹(shù)時(shí),仍然先遍歷左子樹(shù)民逼,再訪問(wèn)根結(jié)點(diǎn),最后遍歷右子樹(shù)。在遍歷上圖[1,2,3]組成的二叉樹(shù)時(shí)坟岔,遍歷結(jié)果為[1,3,2]

方法

中序遍歷二叉樹(shù),如果不用遞歸的方式摔桦,同樣需要借助棧社付。
將當(dāng)前節(jié)點(diǎn)壓棧,然后將當(dāng)前節(jié)點(diǎn)指向左子節(jié)點(diǎn)壓棧邻耕,循環(huán)直至左節(jié)點(diǎn)為空鸥咖。然后從棧里取出節(jié)點(diǎn),同時(shí)取出節(jié)點(diǎn)值兄世。然后將當(dāng)前節(jié)點(diǎn)指向右子節(jié)點(diǎn)啼辣,若當(dāng)前節(jié)點(diǎn)不為空,循環(huán)開(kāi)始的過(guò)程碘饼。直至當(dāng)前節(jié)點(diǎn)為空并且棧為空的時(shí)候熙兔,退出循環(huán)悲伶。

c代碼
#include <assert.h>
#include <stdlib.h>

struct TreeNode {
    int val;
    struct TreeNode *left;
    struct TreeNode *right;
};

/**
 * Return an array of size *returnSize.
 * Note: The returned array must be malloced, assume caller calls free().
 */
int* inorderTraversal(struct TreeNode* root, int* returnSize) {
    struct TreeNode* node;
    struct TreeNode** nodes = (struct TreeNode **)malloc(sizeof(struct TreeNode *) * 1000);
    node = root;
    int nodesTop = 0;
    int* vals = (int *)malloc(sizeof(int) * 1000);
    int valsTop = 0;
    while(node!=NULL || nodesTop!=0) {
        while(node != NULL) {
            nodes[nodesTop++] = node;
            node = node->left;
        }
        node = nodes[--nodesTop];
        vals[valsTop++] = node->val;
        node = node->right;
    }
    *returnSize = valsTop;
    return vals;
}

int main() {
    struct TreeNode* root = (struct TreeNode *)malloc(sizeof(struct TreeNode));
    root->val = 1;
    struct TreeNode* node1_2 = (struct TreeNode *)malloc(sizeof(struct TreeNode));
    node1_2->val = 2;
    root->left = NULL;
    root->right = node1_2;
    struct TreeNode* node2_3 = (struct TreeNode *)malloc(sizeof(struct TreeNode));
    node2_3->val = 3;
    node1_2->left = node2_3;
    node1_2->right = NULL;
    node2_3->left = NULL;
    node2_3->right = NULL;

    int returnSize = 0;
    int* vals = inorderTraversal(root, &returnSize);
    assert(returnSize == 3);
    assert(vals[0] == 1);
    assert(vals[1] == 3);
    assert(vals[2] == 2);

    return 0;
}
擴(kuò)展

前序遍歷二叉樹(shù)
[LeetCode]144. Binary Tree Preorder Traversal

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市住涉,隨后出現(xiàn)的幾起案子麸锉,更是在濱河造成了極大的恐慌,老刑警劉巖舆声,帶你破解...
    沈念sama閱讀 206,839評(píng)論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件花沉,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡媳握,警方通過(guò)查閱死者的電腦和手機(jī)碱屁,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)蛾找,“玉大人娩脾,你說(shuō)我怎么就攤上這事〈蛎” “怎么了柿赊?”我有些...
    開(kāi)封第一講書人閱讀 153,116評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)幻枉。 經(jīng)常有香客問(wèn)我碰声,道長(zhǎng),這世上最難降的妖魔是什么熬甫? 我笑而不...
    開(kāi)封第一講書人閱讀 55,371評(píng)論 1 279
  • 正文 為了忘掉前任胰挑,我火速辦了婚禮,結(jié)果婚禮上椿肩,老公的妹妹穿的比我還像新娘瞻颂。我一直安慰自己,他們只是感情好覆旱,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,384評(píng)論 5 374
  • 文/花漫 我一把揭開(kāi)白布蘸朋。 她就那樣靜靜地躺著,像睡著了一般扣唱。 火紅的嫁衣襯著肌膚如雪藕坯。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書人閱讀 49,111評(píng)論 1 285
  • 那天噪沙,我揣著相機(jī)與錄音炼彪,去河邊找鬼。 笑死正歼,一個(gè)胖子當(dāng)著我的面吹牛辐马,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播局义,決...
    沈念sama閱讀 38,416評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼喜爷,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼冗疮!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起檩帐,我...
    開(kāi)封第一講書人閱讀 37,053評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤术幔,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后湃密,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體诅挑,經(jīng)...
    沈念sama閱讀 43,558評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,007評(píng)論 2 325
  • 正文 我和宋清朗相戀三年泛源,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了拔妥。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,117評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡达箍,死狀恐怖没龙,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情缎玫,我是刑警寧澤兜畸,帶...
    沈念sama閱讀 33,756評(píng)論 4 324
  • 正文 年R本政府宣布,位于F島的核電站碘梢,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏伐蒂。R本人自食惡果不足惜煞躬,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,324評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望逸邦。 院中可真熱鬧恩沛,春花似錦、人聲如沸缕减。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 30,315評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)桥狡。三九已至搅裙,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間裹芝,已是汗流浹背部逮。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 31,539評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留嫂易,地道東北人兄朋。 一個(gè)月前我還...
    沈念sama閱讀 45,578評(píng)論 2 355
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像怜械,于是被迫代替她去往敵國(guó)和親颅和。 傳聞我的和親對(duì)象是個(gè)殘疾皇子傅事,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,877評(píng)論 2 345

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