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

            C++中經(jīng)典的單向鏈表反轉(zhuǎn)

             1 struct linka {
             2 int data;
             3 linka* next;
             4 };
             5 void reverse(linka*& head) {
             6 if(head ==NULL)
             7     return;
             8 linka *pre, *cur, *ne;
             9 pre=head;
            10 cur=head->next;
            11 while(cur)
            12 {
            13    ne = cur->next;
            14    cur->next = pre;
            15    pre = cur;
            16    cur = ne;
            17 }
            18 head->next = NULL;
            19 head = pre;
            20 }

            其中比較難理解的是linka*& head,傳入的其實(shí)就是linka *的類型就可以了,linka *是表示linka類型的指針,&表示head的地址,也就是linka的指針

            另外需要熟悉的是head->next,其實(shí)有點(diǎn)像C#中的head.Next,就是structure中的一個(gè)屬性.

            首先定義3個(gè)指針,分別是前中后,然后當(dāng)中間那個(gè)指針非空,就是當(dāng)前不是空,就做循環(huán)里的事情

            注意的是這個(gè)算法里面next是在循環(huán)里面賦值的

            每次循環(huán)都把current指向previous了,然后大家都往后移一個(gè),next=current->next必須在current改變方向之前做,否則改變了方向之后current的next就變成previous了。

            最后跳出循環(huán)之后,將header的next首先置空,因?yàn)閔ead變成了最后一個(gè)node了。然后head就變成了previous,因?yàn)楫?dāng)時(shí) current和next都為NULL了,只有previous為最后一個(gè)節(jié)點(diǎn)(或者說這時(shí)候應(yīng)該是第一個(gè)非空節(jié)點(diǎn),也就是head)

            終于把整個(gè)算法理解了一遍,最后想想其實(shí)挺簡單,但是能用c++寫出來也不太容易,特別是在面試的時(shí)候。

             

            再增加一個(gè)遞歸的單鏈表反轉(zhuǎn)的方法:


             1 static link ReverseLink3(link pNode)   // using recursion
             2         {
             3             if (pNode.next == null)
             4                 return pNode;
             5             link pNext = pNode.next;
             6             link head = ReverseLink3(pNext);
             7             pNext.next = pNode;
             8             pNode.next = null;
             9             return head;
            10         }

            posted on 2012-11-08 14:15 Beatles 閱讀(1185) 評(píng)論(0)  編輯 收藏 引用 所屬分類: C++

            <2025年7月>
            293012345
            6789101112
            13141516171819
            20212223242526
            272829303112
            3456789

            導(dǎo)航

            統(tǒng)計(jì)

            常用鏈接

            留言簿

            隨筆分類

            隨筆檔案

            搜索

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            国产精品99久久久久久人| 亚洲国产欧洲综合997久久| 日本久久久久亚洲中字幕| 亚州日韩精品专区久久久| 久久久久亚洲av成人无码电影| 国产福利电影一区二区三区,免费久久久久久久精 | 国产高潮国产高潮久久久91 | 亚洲AV日韩精品久久久久| 国内精品伊人久久久久777| 久久精品人人做人人爽电影| 久久人人爽爽爽人久久久| 办公室久久精品| 亚洲午夜福利精品久久| 亚洲国产精品无码久久| 国产女人aaa级久久久级| 一本一本久久a久久精品综合麻豆| 亚洲AV无码久久精品蜜桃| 女人香蕉久久**毛片精品| 久久精品国产亚洲AV不卡| 久久精品国产免费| 亚洲欧洲日产国码无码久久99| 国产精品久久久久9999| 亚洲美日韩Av中文字幕无码久久久妻妇 | 尹人香蕉久久99天天拍| 青青国产成人久久91网| 亚洲精品美女久久777777| 久久九九久精品国产| 国产精品99久久99久久久| 中文字幕久久久久人妻| 久久精品不卡| 国内精品免费久久影院| 国产成人精品久久二区二区| 77777亚洲午夜久久多人| 久久天天躁狠狠躁夜夜不卡| 国内精品久久久久久野外| 亚洲综合伊人久久大杳蕉| 日韩精品无码久久一区二区三 | 国内精品伊人久久久久网站| 蜜臀av性久久久久蜜臀aⅴ麻豆| 久久午夜夜伦鲁鲁片免费无码影视 | 久久亚洲精精品中文字幕|