二叉樹的各種遍歷方法

一、遞歸

先序遍歷

void PreOrderRecur(TreeNode *head){
    if(head==NULL) return;
    std::cout<<head->value<<std::endl;
    PreOrderRecur(head->left);  
    PreOrderRecur(head->right;    
}

中序遍歷

void InOrderRecur(){
    if(head==NULL) return;
    InOrderRecur(head->left);
    std::cout<<head->value<<std::endl;  
    InOrderRecur(head->right;  
}

后序遍歷

void PostOrderRecur(){
    if(head==NULL) return;
    PostOrderRecur(head->left);
    PostOrderRecur(head->right;
    std::cout<<head->value<<std::endl;    
}

二吃度、非遞歸

先序遍歷

孩子結(jié)點入棧的時候甩挫,是右結(jié)點先入棧,保證左結(jié)點在上面先出棧

void PreOrderUnRecur(TreeNode *head){
    if(head != NULL){
        stack<int> mystack;
        mystack.push(head);
        while(!mystack.empty()){
            head = mystack.top(); //彈棧
            std::cout<<head->value<<std::endl;
            mystack.pop();
            if(head->right !=NULL) //先右
                mystack.push(head->right);
            if(head->left !=NULL) //再左
                mystack.push(head->left);
        }
    }
}

中序遍歷

void InOrderUnRecur(TreeNode *head){
    if(head != NULL){
        stack<int> mystack;
        while(!mystack.empty()){
            if(head != NULL){ //一直向左壓棧直到空指針
                mystack.push(head);
                head = head->left;
            }else{
                head = mystack.top(); //以下三句彈棧訪問
                mystack.pop();
                std::cout<<head->value<<std::endl;
                head = head->right; //向左椿每,重復以上步驟
            }
        }
    }
}

后序遍歷 R琳摺!间护!

void PostOrderUnRecur(TreeNode *head){
    if(head !=NULL){
        stack<int> mystack;
        mystack.push(head);
        TreeNode *c =NULL;

        while(!mystack.empty()){
            c = mystack.top(); //棧頂結(jié)點
            if(c->left != NULL && head 亦渗!= c->left && head != c->right) //head 為最近訪問的結(jié)點
                mystack.push(c->left)
            else if(c->right != NULL && head != c->right)
                mystack.push(c->right)
            else{
                std::cout<<c->val<<std::endl;
                mystack.pop();
                head = c;
            }
                
        }
    }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市汁尺,隨后出現(xiàn)的幾起案子法精,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,657評論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件搂蜓,死亡現(xiàn)場離奇詭異狼荞,居然都是意外死亡,警方通過查閱死者的電腦和手機帮碰,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,889評論 3 394
  • 文/潘曉璐 我一進店門粘秆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人收毫,你說我怎么就攤上這事∫罂保” “怎么了此再?”我有些...
    開封第一講書人閱讀 164,057評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長玲销。 經(jīng)常有香客問我输拇,道長,這世上最難降的妖魔是什么贤斜? 我笑而不...
    開封第一講書人閱讀 58,509評論 1 293
  • 正文 為了忘掉前任策吠,我火速辦了婚禮,結(jié)果婚禮上瘩绒,老公的妹妹穿的比我還像新娘猴抹。我一直安慰自己,他們只是感情好锁荔,可當我...
    茶點故事閱讀 67,562評論 6 392
  • 文/花漫 我一把揭開白布蟀给。 她就那樣靜靜地躺著,像睡著了一般阳堕。 火紅的嫁衣襯著肌膚如雪跋理。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,443評論 1 302
  • 那天恬总,我揣著相機與錄音前普,去河邊找鬼。 笑死壹堰,一個胖子當著我的面吹牛拭卿,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播缀旁,決...
    沈念sama閱讀 40,251評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼记劈,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了并巍?” 一聲冷哼從身側(cè)響起目木,我...
    開封第一講書人閱讀 39,129評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后刽射,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體军拟,經(jīng)...
    沈念sama閱讀 45,561評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,779評論 3 335
  • 正文 我和宋清朗相戀三年誓禁,在試婚紗的時候發(fā)現(xiàn)自己被綠了懈息。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,902評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡摹恰,死狀恐怖辫继,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情俗慈,我是刑警寧澤姑宽,帶...
    沈念sama閱讀 35,621評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站闺阱,受9級特大地震影響炮车,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜酣溃,卻給世界環(huán)境...
    茶點故事閱讀 41,220評論 3 328
  • 文/蒙蒙 一瘦穆、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧赊豌,春花似錦扛或、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,838評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至派昧,卻和暖如春黔姜,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背蒂萎。 一陣腳步聲響...
    開封第一講書人閱讀 32,971評論 1 269
  • 我被黑心中介騙來泰國打工秆吵, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人五慈。 一個月前我還...
    沈念sama閱讀 48,025評論 2 370
  • 正文 我出身青樓纳寂,卻偏偏與公主長得像,于是被迫代替她去往敵國和親泻拦。 傳聞我的和親對象是個殘疾皇子毙芜,可洞房花燭夜當晚...
    茶點故事閱讀 44,843評論 2 354

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

  • 酷暑學開車,烈日無蓬遮争拐。 吾不埋怨苦腋粥,夢想作鼓舞。
    時時反省閱讀 279評論 2 9
  • “像我這么善良的人還去哪兒找啊”,以前的我經(jīng)常這么說隘冲。但是最近我越來越意識到自己一點兒也不善良闹瞧。我寫這篇只是發(fā)現(xiàn)了...
    雪糕同學閱讀 1,529評論 0 0
  • 對手機程序板塊的熟悉程度,大家?guī)缀醵剂私庹勾牵酝亩兑糗浖掠剩饾u變成了禁區(qū)。很多相關寫手罗珍,都在網(wǎng)上發(fā)稿子洽腺,強調(diào)抖音區(qū)...
    我是你的福星閱讀 416評論 0 7
  • 51、對稱加密算法和非對稱加密算法 對稱加密算法 對稱加密才用了對稱密碼編碼技術(shù)覆旱,它的特點是文件加密和解密使用...
    cpp加油站閱讀 669評論 0 7