• <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 閱讀(3415) 評論(0)  編輯 收藏 引用 所屬分類: C/C++語言

            <2011年7月>
            262728293012
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            導航

            統計

            公告

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

            留言簿(9)

            隨筆分類(173)

            IT

            Life

            搜索

            積分與排名

            最新隨筆

            最新評論

            閱讀排行榜

            久久精品人妻中文系列| 国产成人久久激情91| 亚洲伊人久久综合中文成人网| 品成人欧美大片久久国产欧美| 国产真实乱对白精彩久久| 少妇被又大又粗又爽毛片久久黑人 | 久久伊人中文无码| 久久久久99这里有精品10| 亚洲精品高清国产一线久久| 色综合久久综合网观看| 亚洲精品国产综合久久一线| 69久久精品无码一区二区| 日韩亚洲国产综合久久久| AV狠狠色丁香婷婷综合久久| 久久福利资源国产精品999| a级毛片无码兔费真人久久| 无码AV中文字幕久久专区| 天天综合久久一二三区| 99久久99久久精品免费看蜜桃| 亚洲性久久久影院| 国产精品激情综合久久| 久久大香香蕉国产| 国内精品综合久久久40p| 久久综合亚洲色HEZYO国产| 久久精品成人国产午夜| 久久狠狠高潮亚洲精品| 精品多毛少妇人妻AV免费久久| 成人午夜精品久久久久久久小说| 欧美噜噜久久久XXX| 亚洲日韩中文无码久久| 思思久久99热只有频精品66| 久久久久香蕉视频| 久久精品国产99国产精品| 国产成人精品久久一区二区三区av| 蜜臀av性久久久久蜜臀aⅴ| 99久久精品国产一区二区 | 亚洲va久久久噜噜噜久久男同 | 亚洲伊人久久精品影院| 老男人久久青草av高清| 国产69精品久久久久9999APGF| 亚洲精品WWW久久久久久|