Reverse Linked List II

Reverse Linked List II


今天是一道有關(guān)鏈表的題目,來自LeetCode伶丐,難度為Medium明吩,Acceptance為26.6%皆串。

題目如下


Reverse a linked list from position m to n. Do it in-place and in one-pass.
For example:
Given 1->2->3->4->5->NULL, m = 2 and n = 4,
return 1->4->3->2->5->NULL.
Note:
Given m, n satisfy the following condition:1 ≤ *m* ≤ *n* ≤ length of list.

解題思路及代碼見閱讀原文

回復(fù)0000查看更多題目

解題思路


首先,該題是Reverse Linked List的升級(jí)版追驴,在Reverse Linked List一題中械哟,是將鏈表整個(gè)翻轉(zhuǎn),比較簡(jiǎn)單:

  • 一種方法是直接翻轉(zhuǎn)殿雪,最后返回尾節(jié)點(diǎn)暇咆。如下
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) { val = x; }
 * }
 */
public class Solution {
    public ListNode reverseList(ListNode head) {
        
        if(null == head)
            return null;
        
        ListNode cur = head, pre = null, next = null;
        
        while(cur != null){
            next = cur.next;
            cur.next = pre;
            pre = cur;
            cur = next;
        }
        return pre;
    }
}
  • 另一種方法是采用頭插法,即先定義一個(gè)新的dummy節(jié)點(diǎn)丙曙,next指向鏈表的頭結(jié)點(diǎn)爸业;然后從head的next節(jié)點(diǎn)開始遍歷鏈表,每一個(gè)遍歷到的節(jié)點(diǎn)的next都指向dummy的next亏镰;同時(shí)dummy的next指向該節(jié)點(diǎn)扯旷。

然后,在該題中加入了翻轉(zhuǎn)鏈表中間的mn個(gè)節(jié)點(diǎn)索抓,這里也可以采用頭插法钧忽,不同的是這里的dummy節(jié)點(diǎn)是m-1個(gè)節(jié)點(diǎn),即在遍歷時(shí)將節(jié)點(diǎn)都查到這個(gè)節(jié)點(diǎn)后面逼肯。

需要注意的是耸黑,這里讓需要生成一個(gè)局部變量dummy節(jié)點(diǎn),為了防止m=1的情況篮幢。

代碼如下


Java版

/**
 * Definition for ListNode
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) {
 *         val = x;
 *         next = null;
 *     }
 * }
 */
public class Solution {
    /**
     * @param ListNode head is the head of the linked list 
     * @oaram m and n
     * @return: The head of the reversed ListNode
     */
    public ListNode reverseBetween(ListNode head, int m , int n) {
        // write your code
        if(null == head)
            return null;
        ListNode dummy= new ListNode(0);
        dummy.next = head;
        ListNode prev = newHead;
        for(int i = 0; i < m - 1; i++) {
            prev = prev.next;
        }
        ListNode first = prev.next, cur = head;
        for(int i = 0; i < m; i++) {
            cur = cur.next;
        }
        for(int i = 0; i < n - m; i++) {
            first.next = cur.next;
            cur.next = prev.next;
            prev.next = cur;
            cur = first.next;
        }
        return dummy.next;        
    }
}

關(guān)注我
該公眾號(hào)會(huì)每天推送常見面試題大刊,包括解題思路是代碼,希望對(duì)找工作的同學(xué)有所幫助

image
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末三椿,一起剝皮案震驚了整個(gè)濱河市缺菌,隨后出現(xiàn)的幾起案子葫辐,更是在濱河造成了極大的恐慌,老刑警劉巖男翰,帶你破解...
    沈念sama閱讀 206,602評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件另患,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡蛾绎,警方通過查閱死者的電腦和手機(jī)昆箕,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,442評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來租冠,“玉大人鹏倘,你說我怎么就攤上這事⊥绲” “怎么了纤泵?”我有些...
    開封第一講書人閱讀 152,878評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長镜粤。 經(jīng)常有香客問我捏题,道長,這世上最難降的妖魔是什么肉渴? 我笑而不...
    開封第一講書人閱讀 55,306評(píng)論 1 279
  • 正文 為了忘掉前任公荧,我火速辦了婚禮,結(jié)果婚禮上同规,老公的妹妹穿的比我還像新娘循狰。我一直安慰自己,他們只是感情好券勺,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,330評(píng)論 5 373
  • 文/花漫 我一把揭開白布绪钥。 她就那樣靜靜地躺著,像睡著了一般关炼。 火紅的嫁衣襯著肌膚如雪程腹。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,071評(píng)論 1 285
  • 那天盗扒,我揣著相機(jī)與錄音跪楞,去河邊找鬼。 笑死侣灶,一個(gè)胖子當(dāng)著我的面吹牛甸祭,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播褥影,決...
    沈念sama閱讀 38,382評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼池户,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起校焦,我...
    開封第一講書人閱讀 37,006評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤赊抖,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后寨典,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體氛雪,經(jīng)...
    沈念sama閱讀 43,512評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,965評(píng)論 2 325
  • 正文 我和宋清朗相戀三年耸成,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了报亩。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,094評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡井氢,死狀恐怖弦追,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情花竞,我是刑警寧澤劲件,帶...
    沈念sama閱讀 33,732評(píng)論 4 323
  • 正文 年R本政府宣布,位于F島的核電站约急,受9級(jí)特大地震影響零远,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜厌蔽,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,283評(píng)論 3 307
  • 文/蒙蒙 一遍烦、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧躺枕,春花似錦、人聲如沸供填。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,286評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽近她。三九已至叉瘩,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間粘捎,已是汗流浹背薇缅。 一陣腳步聲響...
    開封第一講書人閱讀 31,512評(píng)論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留攒磨,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,536評(píng)論 2 354
  • 正文 我出身青樓,卻偏偏與公主長得像坤邪,于是被迫代替她去往敵國和親挪捕。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,828評(píng)論 2 345

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