• <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++語言

            <2025年8月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            導航

            統計

            公告

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

            留言簿(9)

            隨筆分類(173)

            IT

            Life

            搜索

            積分與排名

            最新隨筆

            最新評論

            閱讀排行榜

            精品一二三区久久aaa片| 成人精品一区二区久久久| 91久久成人免费| 久久精品无码专区免费| 国内精品久久久久影院亚洲| 一本久久a久久精品vr综合| 91视频国产91久久久| 久久久久久无码国产精品中文字幕| 一本一本久久a久久精品综合麻豆| 伊人久久大香线蕉AV色婷婷色| 精品精品国产自在久久高清| 久久综合五月丁香久久激情| 久久久久亚洲av无码专区导航| 亚洲精品高清久久| 国产成年无码久久久免费| 成人午夜精品久久久久久久小说| 精品国产99久久久久久麻豆| 国产日韩欧美久久| 精品久久8x国产免费观看| 免费精品国产日韩热久久| 久久亚洲精品国产精品婷婷| 伊人久久久AV老熟妇色| 久久AⅤ人妻少妇嫩草影院| 色综合久久天天综合| 久久精品国产清自在天天线 | 久久无码AV一区二区三区| 亚洲国产精品无码久久一线| 久久se这里只有精品| 老司机国内精品久久久久| 亚洲狠狠婷婷综合久久久久| 精品多毛少妇人妻AV免费久久| 久久99久久99精品免视看动漫| 久久久久se色偷偷亚洲精品av | 三级片免费观看久久| 国产三级久久久精品麻豆三级| 久久久久精品国产亚洲AV无码| 免费一级做a爰片久久毛片潮| 久久99精品久久久久久不卡| 国内精品久久久久国产盗摄| 国产精品亚洲综合专区片高清久久久 | 久久精品国产99国产电影网|