5 從尾到頭打印鏈表

輸入一個鏈表的頭結(jié)點逆趣,從尾到頭打印出每個結(jié)點的值

#include <stdio.h>
#include <stack>
#include "list.h"
void PrintListReversingly_Iteratively(ListNode* pHead)
{
    std::stack<ListNode*> nodes;

    ListNode* pNode = pHead;
    while(pNode != NULL)
    {
        nodes.push(pNode);
        pNode = pNode->m_pNext;
    }

    while(!nodes.empty())
    {
        pNode = nodes.top();
        printf("%d\t", pNode->m_nValue);
        nodes.pop();
    }
}

//既然想到用棧來實現(xiàn),而遞歸本質(zhì)就是一個棧結(jié)構(gòu)仗阅,于是可以
//先遞歸輸出它后面的結(jié)點靴姿,再輸出該結(jié)點携丁,這樣鏈表的輸出結(jié)構(gòu)就反過來了
//缺點是鏈表比較長時瘩扼,函數(shù)調(diào)用的層級很深奴拦,有可能導(dǎo)致函數(shù)調(diào)用棧溢出
void PrintListReversingly_Recursively(ListNode* pHead)
{
    if(pHead != NULL)
    {
        if(pHead->m_pNext != NULL)
        {
            PrintListReversingly_Recursively(pHead->m_pNext);
        }

        printf("%d\t", pHead->m_nValue);
    }
}

void Test(ListNode* pHead)
{
    PrintList(pHead);
    PrintListReversingly_Iteratively(pHead);
    printf("\n");
    PrintListReversingly_Recursively(pHead);
}

// 1->2->3->4->5
void Test1()
{
    printf("\nTest1 begins.\n");

    ListNode* pNode1 = CreateListNode(1);
    ListNode* pNode2 = CreateListNode(2);
    ListNode* pNode3 = CreateListNode(3);
    ListNode* pNode4 = CreateListNode(4);
    ListNode* pNode5 = CreateListNode(5);

    ConnectListNodes(pNode1, pNode2);
    ConnectListNodes(pNode2, pNode3);
    ConnectListNodes(pNode3, pNode4);
    ConnectListNodes(pNode4, pNode5);

    Test(pNode1);

    DestroyList(pNode1);
}

// 只有一個結(jié)點的鏈表: 1
void Test2()
{
    printf("\nTest2 begins.\n");

    ListNode* pNode1 = CreateListNode(1);

    Test(pNode1);

    DestroyList(pNode1);
}

// 空鏈表
void Test3()
{
    printf("\nTest3 begins.\n");

    Test(NULL);
}

int main(void)
{
    Test1();
    Test2();
    Test3();

    return 0;
}

結(jié)果

QQ截圖20160626220946.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末媒鼓,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子错妖,更是在濱河造成了極大的恐慌绿鸣,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,222評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件暂氯,死亡現(xiàn)場離奇詭異潮模,居然都是意外死亡,警方通過查閱死者的電腦和手機痴施,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,455評論 3 385
  • 文/潘曉璐 我一進店門擎厢,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人辣吃,你說我怎么就攤上這事动遭。” “怎么了神得?”我有些...
    開封第一講書人閱讀 157,720評論 0 348
  • 文/不壞的土叔 我叫張陵厘惦,是天一觀的道長。 經(jīng)常有香客問我哩簿,道長宵蕉,這世上最難降的妖魔是什么酝静? 我笑而不...
    開封第一講書人閱讀 56,568評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮羡玛,結(jié)果婚禮上形入,老公的妹妹穿的比我還像新娘。我一直安慰自己缝左,他們只是感情好亿遂,可當(dāng)我...
    茶點故事閱讀 65,696評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著渺杉,像睡著了一般蛇数。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上是越,一...
    開封第一講書人閱讀 49,879評論 1 290
  • 那天耳舅,我揣著相機與錄音,去河邊找鬼倚评。 笑死浦徊,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的天梧。 我是一名探鬼主播盔性,決...
    沈念sama閱讀 39,028評論 3 409
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼呢岗!你這毒婦竟也來了冕香?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,773評論 0 268
  • 序言:老撾萬榮一對情侶失蹤后豫,失蹤者是張志新(化名)和其女友劉穎悉尾,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體挫酿,經(jīng)...
    沈念sama閱讀 44,220評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡构眯,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,550評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了早龟。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片惫霸。...
    茶點故事閱讀 38,697評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖拄衰,靈堂內(nèi)的尸體忽然破棺而出它褪,到底是詐尸還是另有隱情,我是刑警寧澤翘悉,帶...
    沈念sama閱讀 34,360評論 4 332
  • 正文 年R本政府宣布茫打,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏老赤。R本人自食惡果不足惜轮洋,卻給世界環(huán)境...
    茶點故事閱讀 40,002評論 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望抬旺。 院中可真熱鬧弊予,春花似錦、人聲如沸开财。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,782評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽责鳍。三九已至碾褂,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間历葛,已是汗流浹背正塌。 一陣腳步聲響...
    開封第一講書人閱讀 32,010評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留恤溶,地道東北人乓诽。 一個月前我還...
    沈念sama閱讀 46,433評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像咒程,于是被迫代替她去往敵國和親鸠天。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,587評論 2 350

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