4.單鏈表逆序

題目:給定一個帶附加頭節(jié)點的單鏈表稀拐,設(shè)first為其頭指針啸澡,節(jié)點的結(jié)構(gòu)為(data,link),data為數(shù)據(jù)域慰毅,link為指針域隘截,試寫出算法:通過遍歷一趟鏈表,將鏈表中所有節(jié)點逆序連接
  分析:這是很經(jīng)典的“單鏈表逆序”問題汹胃。很多公司的面試題庫中都有這道題婶芭,有的公司明確題目要求不能開辟額外的節(jié)點空間(否則可以在遍歷原鏈表的同時使用前插法建立一個逆序鏈表),有的沒有明確說明着饥,但是如果面試者使用了額外的節(jié)點存儲空間犀农,會得到一個比較低的分數(shù)。如何在不使用額外節(jié)點的情況下使一個單鏈表的所有節(jié)點逆序宰掉?我們先用迭代循環(huán)的思想來分析這個問題呵哨。
    這種方法需要另外定義一個前驅(qū)指針prev和后繼指針latter赁濒。初始狀態(tài),p指向當前節(jié)點即第一個節(jié)點A孟害,prev為NULL拒炎,latter指向A的下一個節(jié)點B。鏈表的初始狀態(tài)如下圖所示:

從A節(jié)點開始逆序纹坐,首先將A節(jié)點的link指針指向prev(因為prev的當前值是NULL枝冀,所以A節(jié)點就從鏈表中脫離出來了),然后整體后移耘子,prev指向p果漾,后移p和latter指針。逆向節(jié)點A之后谷誓,鏈表的狀態(tài)如下圖所示:

     

從圖(1)的初始狀態(tài)到圖(2)狀態(tài)共做了四個操作绒障,這四個操作的偽代碼如下:

p->link = prev;
prev = p;
p = latter;
latter = p->link;

這四行偽代碼就是循環(huán)算法的迭代體了,現(xiàn)在用這個迭代體對圖(2)的狀態(tài)再進行一輪迭代捍歪,就得到了下圖的狀態(tài):

      

那么循環(huán)終止條件呢户辱?現(xiàn)在對圖(3)的狀態(tài)再迭代一次得到下圖的狀態(tài):

       

此時可以看出,在圖(4)的基礎(chǔ)上再進行一次迭代就可以完成鏈表的逆序糙臼,因此循環(huán)迭代的終止條件就是p指針為NULL庐镐。當然,最后還要注意將附加頭節(jié)點放到首節(jié)點的前面变逃。
  
源碼

void List<T>::Inverse()                
{
    if(first == NULL)    return;
    LinkNode<T> *p, *prev, *latter;    
    p = first->link;      // 當前結(jié)點
    prev = NULL;          // 前一結(jié)點
    latter = p->link;      // 下一結(jié)點
    while(p != NULL)
    {
        p->link = prev;      // 當前結(jié)點指針指向前一結(jié)點
        prev = p;            // 后移
        p = latter;
        if(p != NULL)        // 如果p指針是NULL必逆,已經(jīng)滿足終止條件
            latter = p->link;
    }
    first->link = prev;;    // 最后連上附加頭結(jié)點
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市揽乱,隨后出現(xiàn)的幾起案子名眉,更是在濱河造成了極大的恐慌,老刑警劉巖凰棉,帶你破解...
    沈念sama閱讀 221,888評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件损拢,死亡現(xiàn)場離奇詭異,居然都是意外死亡撒犀,警方通過查閱死者的電腦和手機福压,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,677評論 3 399
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來或舞,“玉大人隧膏,你說我怎么就攤上這事∪履牵” “怎么了胞枕?”我有些...
    開封第一講書人閱讀 168,386評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長魏宽。 經(jīng)常有香客問我腐泻,道長决乎,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,726評論 1 297
  • 正文 為了忘掉前任派桩,我火速辦了婚禮构诚,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘铆惑。我一直安慰自己范嘱,他們只是感情好,可當我...
    茶點故事閱讀 68,729評論 6 397
  • 文/花漫 我一把揭開白布员魏。 她就那樣靜靜地躺著丑蛤,像睡著了一般。 火紅的嫁衣襯著肌膚如雪撕阎。 梳的紋絲不亂的頭發(fā)上受裹,一...
    開封第一講書人閱讀 52,337評論 1 310
  • 那天,我揣著相機與錄音虏束,去河邊找鬼棉饶。 笑死,一個胖子當著我的面吹牛镇匀,可吹牛的內(nèi)容都是我干的照藻。 我是一名探鬼主播,決...
    沈念sama閱讀 40,902評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼汗侵,長吁一口氣:“原來是場噩夢啊……” “哼幸缕!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起晃择,我...
    開封第一講書人閱讀 39,807評論 0 276
  • 序言:老撾萬榮一對情侶失蹤冀值,失蹤者是張志新(化名)和其女友劉穎也物,沒想到半個月后宫屠,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,349評論 1 318
  • 正文 獨居荒郊野嶺守林人離奇死亡滑蚯,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,439評論 3 340
  • 正文 我和宋清朗相戀三年浪蹂,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片告材。...
    茶點故事閱讀 40,567評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡坤次,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出斥赋,到底是詐尸還是另有隱情缰猴,我是刑警寧澤,帶...
    沈念sama閱讀 36,242評論 5 350
  • 正文 年R本政府宣布疤剑,位于F島的核電站滑绒,受9級特大地震影響闷堡,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜疑故,卻給世界環(huán)境...
    茶點故事閱讀 41,933評論 3 334
  • 文/蒙蒙 一杠览、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧纵势,春花似錦踱阿、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,420評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至育瓜,卻和暖如春葫隙,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背躏仇。 一陣腳步聲響...
    開封第一講書人閱讀 33,531評論 1 272
  • 我被黑心中介騙來泰國打工恋脚, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人焰手。 一個月前我還...
    沈念sama閱讀 48,995評論 3 377
  • 正文 我出身青樓糟描,卻偏偏與公主長得像,于是被迫代替她去往敵國和親书妻。 傳聞我的和親對象是個殘疾皇子船响,可洞房花燭夜當晚...
    茶點故事閱讀 45,585評論 2 359

推薦閱讀更多精彩內(nèi)容

  • 第一章 Nginx簡介 Nginx是什么 沒有聽過Nginx?那么一定聽過它的“同行”Apache吧躲履!Ngi...
    JokerW閱讀 32,700評論 24 1,002
  • 本文內(nèi)容:1见间、 什么是鏈表?2工猜、 鏈表共分幾類米诉?3、 鏈表的 C 實現(xiàn)篷帅! 總表:《數(shù)據(jù)結(jié)構(gòu)史侣?》 工程代碼 Gith...
    半紙淵閱讀 39,985評論 0 54
  • 鏈表問題是面試過程中經(jīng)常被問到的一部分,很考查編程功底魏身。最近刷了 LeetCode 上鏈表部分的面試題惊橱,我總結(jié)了一...
    JohnnyShieh閱讀 4,963評論 0 9
  • 本文為原創(chuàng)文章,如需轉(zhuǎn)載請注明出處箭昵,謝謝! 扯淡 今天出去面試又碰到這題了税朴,從畢業(yè)到現(xiàn)在面試這么多次,也碰上了不少...
    Android_ZzT閱讀 1,578評論 2 9
  • 肖蛇者于猴年屬合太歲、刑太歲及破太歲正林,運勢反復(fù)多變茧跋;來到丁酉雞年,其運勢走向很大程度上乃承接猴年的變化卓囚。倘若在猴年...
    九號館閱讀 330評論 0 0