• 21. Merge Two Sorted Lists


    https://leetcode.com/problems/merge-two-sorted-lists/#/description

    Merge two sorted linked lists and return it as a new list. The new list should be made by splicing together the nodes of the first two lists.

    Sol 1:

    Always better to solve linked list problems using recursion. 

    Make sure the returned list starts with smaller node of list 1 and list 2.  

    Recursion.

    # 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 or not l2:
                return l1 or l2
            if l1.val < l2.val:
                l1.next = self.mergeTwoLists(l1.next, l2)
                return l1
            else:
                l2.next = self.mergeTwoLists(l1,l2.next)
                return l2

    Note:

    1 The recursive part the the next link of list 1 or 2. 

    2 Return a list. 

    Sol 2:

    Recursion.

    # 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 both lists are non-empty, I first make sure a starts smaller, use its head as result, and merge the remainders behind it. Otherwise, i.e., if one or both are empty, I just return what's there.
            if l1 and l2:
                if l1.val > l2.val:
                    l1,l2 = l2,l1
                l1.next = self.mergeTwoLists(l1.next, l2)
            return l1 or l2
                

    Sol 3:

    iteratively, O(min(m,n) Space, O(1), in-place

    # 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
            """
            # dummy node is the first node of a linked list, it is also called guard node
            dummy = cur = ListNode(0)
            while l1 and l2:
                if l1.val < l2.val:
                    # choose which node to add to cur
                    cur.next = l1
                    # advance l1, create l1
                    l1 = l1.next
                else:
                    cur.next = l2
                    l2 = l2.next
                # after adding l1 or l2 to cur, create cur
                cur = cur.next
            # assign value to cur.next
            cur.next = l1 or l2
            return dummy.next
                

    Sol 4:

    iteratively, O(min(m,n) Space, O(1), in-place

    # 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
            """
            # cur list is based on l1 and use a tmp varible to add l2 to cur list
            if None in (l1, l2):
                # or returns the non-None list
                return l1 or l2
            dummy = cur = ListNode(0)
            dummy.next = l1
            while l1 and l2:
                if l1.val < l2.val:
                    l1 = l1.next
                else:
                    # store the next link of cur before overwrite it
                    nxt = cur.next
                    # overwrite the next link of cur with l2 
                    cur.next = l2
                    # store the next link of l2 before overwrite it
                    tmp = l2.next
                    # overwrite the next link of l2 with the next link of cur. i.e. the next link of l2 is now assigned to the next link of cur
                    l2.next = nxt
                    # advance l2
                    l2 = tmp
                # advance cur
                cur = cur.next
            # assign the value of the next link of cur
            cur.next = l1 or l2
            return dummy.next
                

    For linked list, recursion beats iteration! Yay!

  • 相关阅读:
    I.MX6 Parallel RGB LCD Datasheet描述
    ubuntu IP 扫描
    I.MX6 按键开关机 PMIC 检测
    java中对List中对象排序实现
    jQuery实现父窗口的问题
    如何在Oracle中复制表结构和表数据
    handsontable常规配置的中文API
    oracle中to_date详细用法示例(oracle日期格式转换)
    js中子页面父页面方法和变量相互调用
    关于Ajax的type为post提交方式出现请求失效问题
  • 原文地址:https://www.cnblogs.com/prmlab/p/6994783.html
Copyright © 2020-2023  润新知