• <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++中經典的單向鏈表反轉

             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,傳入的其實就是linka *的類型就可以了,linka *是表示linka類型的指針,&表示head的地址,也就是linka的指針

            另外需要熟悉的是head->next,其實有點像C#中的head.Next,就是structure中的一個屬性.

            首先定義3個指針,分別是前中后,然后當中間那個指針非空,就是當前不是空,就做循環里的事情

            注意的是這個算法里面next是在循環里面賦值的

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

            最后跳出循環之后,將header的next首先置空,因為head變成了最后一個node了。然后head就變成了previous,因為當時 current和next都為NULL了,只有previous為最后一個節點(或者說這時候應該是第一個非空節點,也就是head)

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

             

            再增加一個遞歸的單鏈表反轉的方法:


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

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

            導航

            統計

            常用鏈接

            留言簿

            隨筆分類

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            久久99精品久久久久久hb无码 | 亚洲精品国产字幕久久不卡| 久久久久久国产精品无码下载| 国产精品亚洲综合专区片高清久久久| 久久se精品一区二区影院| 久久影院久久香蕉国产线看观看| 亚洲国产成人乱码精品女人久久久不卡 | 久久久久亚洲AV片无码下载蜜桃| 2019久久久高清456| 国产精品久久久久久久| 亚洲欧洲久久av| 久久婷婷国产麻豆91天堂| 午夜精品久久久久成人| 97久久超碰成人精品网站| 亚洲精品成人网久久久久久| 国产欧美久久一区二区| 老色鬼久久亚洲AV综合| 久久青青草原精品国产软件| 国产精品一区二区久久| 欧美一区二区三区久久综| 少妇被又大又粗又爽毛片久久黑人| 波多野结衣中文字幕久久| 亚洲欧美成人久久综合中文网| 91精品国产乱码久久久久久| 2021国内精品久久久久久影院| 91精品国产91热久久久久福利| 久久久噜噜噜www成人网| 亚洲国产精品一区二区三区久久| 久久99中文字幕久久| 久久国产精品久久国产精品| 亚洲va久久久噜噜噜久久男同 | 一本一道久久精品综合| 一级做a爰片久久毛片16| a级成人毛片久久| 国产成人久久激情91| 99国产欧美久久久精品蜜芽 | 成人午夜精品无码区久久| 无码人妻久久一区二区三区蜜桃| 亚洲国产精品一区二区三区久久| 欧美一级久久久久久久大片| 一级做a爰片久久毛片免费陪|