• <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>

            無我

            讓內(nèi)心永遠(yuǎn)燃燒著偉大的光明的精神之火!
            靈活的思考,嚴(yán)謹(jǐn)?shù)膶?shí)現(xiàn)
            豪邁的氣魄、頑強(qiáng)的意志和周全的思考

            鏈表逆序的循環(huán)實(shí)現(xiàn)和遞歸實(shí)現(xiàn)

             鏈表逆序:
            一個鏈表的結(jié)點(diǎn)結(jié)構(gòu)
            struct Node
            {
            int data ;
            Node *next ;
            };
            typedef struct Node Node ;

            已知鏈表的頭結(jié)點(diǎn)head,寫一個函數(shù)把這個鏈表逆序 ( Intel)。

             鏈表逆序是筆試中鏈表測試的經(jīng)典題,這次自己寫了一下代碼,分別用循環(huán)和遞歸方法做兩種實(shí)現(xiàn),記錄在此。

             1#include <iostream>
             2using namespace std;
             3
             4struct Node
             5{
             6    int data ;
             7    Node *next ;
             8}
            ;
             9//鏈表反序的循環(huán)實(shí)現(xiàn)
            10Node * ReverseList(Node *head)
            11{
            12    Node * p1 = NULL;//p1代表鏈表被反序好的部分的頭結(jié)點(diǎn)
            13    Node * p2 = head;//p2代表鏈表還沒有被反序部分的頭結(jié)點(diǎn)
            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//鏈表反序的遞歸實(shí)現(xiàn)
            24Node * ReverseList_DG(Node *head,Node * last=NULL)
            25{
            26    //last代表鏈表被反序好的部分的頭結(jié)點(diǎn),head代表鏈表還沒有被反序部分的頭結(jié)點(diǎn)
            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    //循環(huán)法反序鏈表并輸出
            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 閱讀(3408) 評論(0)  編輯 收藏 引用 所屬分類: C/C++語言

            <2012年11月>
            28293031123
            45678910
            11121314151617
            18192021222324
            2526272829301
            2345678

            導(dǎo)航

            統(tǒng)計

            公告

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

            留言簿(9)

            隨筆分類(173)

            IT

            Life

            搜索

            積分與排名

            最新隨筆

            最新評論

            閱讀排行榜

            久久精品国产精品亚洲艾草网美妙| 久久亚洲国产精品成人AV秋霞| 久久婷婷五月综合色奶水99啪| 99精品国产综合久久久久五月天| 漂亮人妻被中出中文字幕久久| 久久精品国产男包| 久久综合九色综合精品| 久久综合九色综合久99| 亚洲第一极品精品无码久久| 久久国产高清字幕中文| 久久亚洲高清综合| 99久久成人国产精品免费| 久久av高潮av无码av喷吹| 99蜜桃臀久久久欧美精品网站| 亚洲成色999久久网站| 国产精品久久婷婷六月丁香| 久久最新精品国产| 久久精品天天中文字幕人妻| 欧美国产成人久久精品| 狠狠色丁香久久婷婷综| 人妻无码精品久久亚瑟影视 | 亚洲国产成人久久一区久久| 一本大道久久东京热无码AV | 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 久久99免费视频| 超级97碰碰碰碰久久久久最新| 久久91精品国产91久久麻豆| 久久影视综合亚洲| 久久国产成人精品国产成人亚洲| 久久超乳爆乳中文字幕| 久久久婷婷五月亚洲97号色| 久久精品国产男包| 亚洲va久久久噜噜噜久久| 久久九九久精品国产免费直播| 久久久久国产精品嫩草影院| 国产成人无码精品久久久免费| 国产精品一区二区久久国产| 精品蜜臀久久久久99网站| 欧美一区二区三区久久综合| 久久天天躁狠狠躁夜夜躁2O2O| 国产精品久久午夜夜伦鲁鲁|