[Leetcode]21. 合并兩個(gè)有序鏈表

題目描述:

將兩個(gè)有序鏈表合并為一個(gè)新的有序鏈表并返回尊惰。新鏈表是通過(guò)拼接給定的兩個(gè)鏈表的所有節(jié)點(diǎn)組成的温数。
示例:

  • 輸入:1->2->4, 1->3->4
  • 輸出:1->1->2->3->4->4

我的方法:

這個(gè)題目比較簡(jiǎn)單,解法如下:

  1. 兩個(gè)指針?lè)謩e指向兩個(gè)鏈表的頭部搬味。
  2. 比較對(duì)應(yīng)位置的數(shù)字大小,記錄較小的字符,對(duì)應(yīng)的指針移到下一位椿猎。
  3. 直到兩個(gè)鏈表都遍歷完惶岭。

效果還不錯(cuò):執(zhí)行用時(shí) : 32 ms, 在Merge Two Sorted Lists的Python提交中擊敗了99.60% 的用戶。內(nèi)存消耗 : 10.8 MB, 在Merge Two Sorted Lists的Python提交中擊敗了0.57% 的用戶犯眠。

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

class Solution(object):
    def mergeTwoLists(self, l1, l2):
        """
        :type l1: ListNode
        :type l2: ListNode
        :rtype: ListNode
        """
        ans=ListNode(0)
        head=ans
        while l1 and l2:
            if l1.val <= l2.val:
                ans.next=l1
                ans=ans.next # 注意:ans也要移動(dòng)
                l1=l1.next
            else:
                ans.next=l2
                ans=ans.next # 注意:ans也要移動(dòng)
                l2=l2.next
        ans.next=l1 if l1 else l2
        return head.next
                

別人的方法:

也有人用遞歸的方法按灶,雖然速度略慢,但思路依然可以借鑒筐咧。處理步驟如下:

  1. mergeTwoLists(self,l1,l2)的主要功能鸯旁,是將兩個(gè)有序鏈表合成一個(gè)有序鏈表。遞歸只需要關(guān)注移動(dòng)和終止條件兩個(gè)問(wèn)題量蕊。
  2. 終止條件是l1為空或者l2為空铺罢。如果l1為空,則返回l2残炮;如果l2為空韭赘,則返回l1。
  3. 遞歸事實(shí)上是問(wèn)題拆解為子問(wèn)題的過(guò)程势就,本題是將merge(l1,l2)轉(zhuǎn)化為merge(l1.next,l2)或者merge(l1,l2.next)泉瞻。通過(guò)這種轉(zhuǎn)化,實(shí)現(xiàn)鏈表的移動(dòng)蛋勺。
  4. 最終返回head.next瓦灶。

最終運(yùn)行效率一般,遞歸的效率一般都不是最高的抱完。執(zhí)行用時(shí) : 36 ms, 在Merge Two Sorted Lists的Python提交中擊敗了50.40% 的用戶贼陶。內(nèi)存消耗 : 10.9 MB, 在Merge Two Sorted Lists的Python提交中擊敗了0.57% 的用戶。

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

class Solution(object):
    def mergeTwoLists(self, l1, l2):
        """
        :type l1: ListNode
        :type l2: ListNode
        :rtype: ListNode
        """
        # 終止條件
        if not l1: return l2
        if not l2: return l1
        
        head = ListNode(0)
        # 當(dāng)l1.val<l2.val巧娱,則l1向后移動(dòng)一位
        if l1.val < l2.val:
            l1.next = self.mergeTwoLists(l1.next, l2)
            head.next = l1
        # 否則碉怔,l2向后移動(dòng)一位
        else:
            l2.next = self.mergeTwoLists(l1, l2.next)
            head.next = l2
            
        return head.next
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市禁添,隨后出現(xiàn)的幾起案子撮胧,更是在濱河造成了極大的恐慌,老刑警劉巖老翘,帶你破解...
    沈念sama閱讀 211,194評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件芹啥,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡铺峭,警方通過(guò)查閱死者的電腦和手機(jī)墓怀,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)卫键,“玉大人傀履,你說(shuō)我怎么就攤上這事±蚵” “怎么了钓账?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,780評(píng)論 0 346
  • 文/不壞的土叔 我叫張陵碴犬,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我梆暮,道長(zhǎng)服协,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,388評(píng)論 1 283
  • 正文 為了忘掉前任啦粹,我火速辦了婚禮蚯涮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘卖陵。我一直安慰自己,他們只是感情好张峰,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,430評(píng)論 5 384
  • 文/花漫 我一把揭開(kāi)白布泪蔫。 她就那樣靜靜地躺著,像睡著了一般喘批。 火紅的嫁衣襯著肌膚如雪撩荣。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,764評(píng)論 1 290
  • 那天饶深,我揣著相機(jī)與錄音餐曹,去河邊找鬼。 笑死敌厘,一個(gè)胖子當(dāng)著我的面吹牛台猴,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播俱两,決...
    沈念sama閱讀 38,907評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼饱狂,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了宪彩?” 一聲冷哼從身側(cè)響起休讳,我...
    開(kāi)封第一講書(shū)人閱讀 37,679評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎尿孔,沒(méi)想到半個(gè)月后俊柔,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,122評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡活合,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,459評(píng)論 2 325
  • 正文 我和宋清朗相戀三年雏婶,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片芜辕。...
    茶點(diǎn)故事閱讀 38,605評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡尚骄,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出侵续,到底是詐尸還是另有隱情倔丈,我是刑警寧澤憨闰,帶...
    沈念sama閱讀 34,270評(píng)論 4 329
  • 正文 年R本政府宣布,位于F島的核電站需五,受9級(jí)特大地震影響鹉动,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜宏邮,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,867評(píng)論 3 312
  • 文/蒙蒙 一泽示、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧蜜氨,春花似錦械筛、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,734評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至郎汪,卻和暖如春赤赊,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背煞赢。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,961評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工抛计, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人照筑。 一個(gè)月前我還...
    沈念sama閱讀 46,297評(píng)論 2 360
  • 正文 我出身青樓吹截,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親朦肘。 傳聞我的和親對(duì)象是個(gè)殘疾皇子饭弓,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,472評(píng)論 2 348

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