92. &206 Reverse Linked List II

題目要求:

Reverse a linked list from position m to n. Do it in-place and in one-pass.

For examples:

Given 1->2->3->4->5->NULL, m = 2 and n = 4,
return 1->4->3->2->5->NULL.

解題思路:尋找關(guān)鍵節(jié)點(diǎn)
  • 將head后移m-1個(gè)位置,找到逆置節(jié)點(diǎn),記錄其前驅(qū)節(jié)點(diǎn)和自己卷雕。


    步驟一
  • 從head節(jié)點(diǎn)開(kāi)始逆置,逆置(m-n+1)個(gè)節(jié)點(diǎn)
  • 將所有節(jié)點(diǎn)相連


    步驟二棠耕、三
class ListNode():
    def __init__(self, x):
        self.val = x
        self.next = None

    def __repr__(self):
        if self:
            return "{} -> {}".format(self.val, repr(self.next))

class Solution(object):
    def reverseBetween(self, head, m, n):
        """
        :type head: ListNode
        :type m: int
        :type n: int
        :rtype: ListNode
        """
        # 有可能是從第一個(gè)節(jié)點(diǎn)開(kāi)始逆序,所以pre指針并不能指向head柠新,pre指針一般都是置為None

        pre = None
        m = m - 1
        length = n - m
        result = head

        # 將head放在逆序的開(kāi)始位置
        while head and m:
            pre = head
            head = head.next
            m -= 1

        # 逆序的第一個(gè)節(jié)點(diǎn)將是逆序后的最后一個(gè)節(jié)點(diǎn)窍荧,需要保存為tail
        new_node = None
        next = None
        tail = head
        while head and length:
            next = head.next
            head.next = new_node
            new_node = head
            head = next
            length -= 1
        tail.next = head

        if pre:
            pre.next = new_node
        else:
            result = new_node

        return result

if __name__ == "__main__":
    head = ListNode(1)
    head.next = ListNode(2)
    head.next.next = ListNode(3)
    head.next.next.next = ListNode(4)
    head.next.next.next.next = ListNode(5)
    print(Solution().reverseBetween(head, 2, 4))

自己的新方法:

# Definition for singly-linked list.
# class ListNode(object):
#     def __init__(self, x):
#         self.val = x
#         self.next = None

class Solution(object):
    def reverseBetween(self, head, m, n):
        """
        :type head: ListNode
        :type m: int
        :type n: int
        :rtype: ListNode
        """
        diff, dummy, cur = n - m + 1, ListNode(-1), head
        dummy.next = head
        
        last_unswapped = dummy
        while head and m > 1:   #將cur放在逆序的開(kāi)始位置,last_unsnapped
            cur, last_unswapped, m = cur.next, cur, m - 1
            
        prev = last_unswapped
        first_swapped = cur
        while cur and diff > 0:
            prev.next, cur.next, cur, diff = cur, prev.next, cur.next, diff - 1   #新學(xué)的方法,哈哈哈哈哈哈哈
        
        last_unswapped, first_swapped.next = prev, cur    #last_unswapped不要賦值
        
        return dummy.next
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末恨憎,一起剝皮案震驚了整個(gè)濱河市蕊退,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌憔恳,老刑警劉巖瓤荔,帶你破解...
    沈念sama閱讀 222,000評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異钥组,居然都是意外死亡输硝,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,745評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門程梦,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)腔丧,“玉大人,你說(shuō)我怎么就攤上這事作烟≡芪。” “怎么了版确?”我有些...
    開(kāi)封第一講書人閱讀 168,561評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵安寺,是天一觀的道長(zhǎng)斧蜕。 經(jīng)常有香客問(wèn)我宛琅,道長(zhǎng),這世上最難降的妖魔是什么大州? 我笑而不...
    開(kāi)封第一講書人閱讀 59,782評(píng)論 1 298
  • 正文 為了忘掉前任括改,我火速辦了婚禮,結(jié)果婚禮上探赫,老公的妹妹穿的比我還像新娘型宙。我一直安慰自己,他們只是感情好伦吠,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,798評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布妆兑。 她就那樣靜靜地躺著,像睡著了一般毛仪。 火紅的嫁衣襯著肌膚如雪搁嗓。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書人閱讀 52,394評(píng)論 1 310
  • 那天箱靴,我揣著相機(jī)與錄音腺逛,去河邊找鬼。 笑死衡怀,一個(gè)胖子當(dāng)著我的面吹牛棍矛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播抛杨,決...
    沈念sama閱讀 40,952評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼够委,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了蝶桶?” 一聲冷哼從身側(cè)響起慨绳,我...
    開(kāi)封第一講書人閱讀 39,852評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎真竖,沒(méi)想到半個(gè)月后脐雪,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,409評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡恢共,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,483評(píng)論 3 341
  • 正文 我和宋清朗相戀三年战秋,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片讨韭。...
    茶點(diǎn)故事閱讀 40,615評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡脂信,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出透硝,到底是詐尸還是另有隱情狰闪,我是刑警寧澤,帶...
    沈念sama閱讀 36,303評(píng)論 5 350
  • 正文 年R本政府宣布濒生,位于F島的核電站埋泵,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜丽声,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,979評(píng)論 3 334
  • 文/蒙蒙 一礁蔗、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧雁社,春花似錦浴井、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 32,470評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至喊巍,卻和暖如春屠缭,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背崭参。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,571評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工呵曹, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人何暮。 一個(gè)月前我還...
    沈念sama閱讀 49,041評(píng)論 3 377
  • 正文 我出身青樓奄喂,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親海洼。 傳聞我的和親對(duì)象是個(gè)殘疾皇子跨新,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,630評(píng)論 2 359

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