• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            無我

            讓內心永遠燃燒著偉大的光明的精神之火!
            靈活的思考,嚴謹的實現
            豪邁的氣魄、頑強的意志和周全的思考

            鏈表逆序的循環實現和遞歸實現

             鏈表逆序:
            一個鏈表的結點結構
            struct Node
            {
            int data ;
            Node *next ;
            };
            typedef struct Node Node ;

            已知鏈表的頭結點head,寫一個函數把這個鏈表逆序 ( Intel)。

             鏈表逆序是筆試中鏈表測試的經典題,這次自己寫了一下代碼,分別用循環和遞歸方法做兩種實現,記錄在此。

             1#include <iostream>
             2using namespace std;
             3
             4struct Node
             5{
             6    int data ;
             7    Node *next ;
             8}
            ;
             9//鏈表反序的循環實現
            10Node * ReverseList(Node *head)
            11{
            12    Node * p1 = NULL;//p1代表鏈表被反序好的部分的頭結點
            13    Node * p2 = head;//p2代表鏈表還沒有被反序部分的頭結點
            14    while(p2)
            15    {
            16        Node * pTemp = p2->next;
            17        p2->next = p1;
            18        p1 = p2;
            19        p2 = pTemp;
            20    }

            21    return p1;
            22}

            23//鏈表反序的遞歸實現
            24Node * ReverseList_DG(Node *head,Node * last=NULL)
            25{
            26    //last代表鏈表被反序好的部分的頭結點,head代表鏈表還沒有被反序部分的頭結點
            27    if (head == NULL) return last;    
            28    Node * pTemp = head->next;    
            29    head->next = last;    
            30    ReverseList_DG(pTemp,head);
            31}

            32
            33int main(int argc, char* argv[])
            34{    
            35    Node * pHead = new Node,*pTemp;
            36    pHead->data = 0;
            37    pHead->next = NULL;
            38    for (int i=1;i<10;++i)
            39    {
            40        pTemp = new Node;
            41        pTemp->data = i;
            42        pTemp->next = pHead;
            43        pHead = pTemp;
            44    }

            45    //打印出原始鏈表
            46    pTemp = pHead;
            47    while(pTemp)
            48    {
            49        cout<<pTemp->data<<",";
            50        pTemp = pTemp->next;
            51    }

            52    cout<<endl;
            53    //循環法反序鏈表并輸出
            54    pHead = ReverseList(pHead);
            55    pTemp = pHead;
            56    while(pTemp)
            57    {
            58        cout<<pTemp->data<<",";
            59        pTemp = pTemp->next;
            60    }

            61    cout<<endl;
            62    //遞歸法反序鏈表并輸出
            63    pHead = ReverseList_DG(pHead);
            64    pTemp = pHead;
            65    while(pTemp)
            66    {
            67        cout<<pTemp->data<<",";
            68        pTemp = pTemp->next;
            69    }

            70    cout<<endl;    
            71    
            72    return 0;
            73}


             

            posted on 2012-11-05 08:44 Tim 閱讀(3421) 評論(0)  編輯 收藏 引用 所屬分類: C/C++語言

            <2012年4月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            293012345

            導航

            統計

            公告

            本博客原創文章,歡迎轉載和交流。不過請注明以下信息:
            作者:TimWu
            郵箱:timfly@yeah.net
            來源:www.shnenglu.com/Tim
            感謝您對我的支持!

            留言簿(9)

            隨筆分類(173)

            IT

            Life

            搜索

            積分與排名

            最新隨筆

            最新評論

            閱讀排行榜

            久久久久久伊人高潮影院| 亚洲成色999久久网站| 久久精品国产亚洲αv忘忧草 | 999久久久国产精品| 久久综合精品国产一区二区三区| 久久伊人五月天论坛| 五月丁香综合激情六月久久| 青青草原综合久久| 久久毛片一区二区| 国产激情久久久久影院| 亚洲欧美成人综合久久久| 99久久亚洲综合精品成人| 日韩人妻无码一区二区三区久久99| 无码人妻精品一区二区三区久久久| 91精品久久久久久无码| 欧美激情一区二区久久久| 99久久超碰中文字幕伊人| 伊人久久大香线蕉亚洲| 国内精品久久久久久中文字幕| 久久久久久亚洲精品成人 | 久久99热这里只有精品国产| 色综合久久最新中文字幕| 久久久久99精品成人片试看| 日本久久中文字幕| 曰曰摸天天摸人人看久久久| 日本久久久久亚洲中字幕 | 久久精品国产一区| 久久亚洲中文字幕精品有坂深雪| 色婷婷综合久久久久中文字幕| 亚洲综合精品香蕉久久网97| 久久精品人人做人人爽电影蜜月| 久久精品青青草原伊人| 欧美黑人激情性久久| 国产精品99久久久精品无码| 亚洲国产日韩欧美久久| 久久婷婷五月综合成人D啪| 国内精品久久久久影院网站 | 欧美亚洲国产精品久久| 日韩一区二区三区视频久久| 欧美午夜A∨大片久久| 狠狠色丁香婷婷久久综合五月 |