21. Merge Two Sorted Lists

개꡴·2024λ…„ 6μ›” 24일

leetcode

λͺ©λ‘ 보기
39/51
  • python3

πŸ“Ž Problem

You are given the heads of two sorted linked lists list1 and list2.

Merge the two lists into one sorted list. The list should be made by splicing together the nodes of the first two lists.

Return the head of the merged linked list.

Example 1:

Input: list1 = [1,2,4], list2 = [1,3,4]
Output: [1,1,2,3,4,4]

Example 2:

Input: list1 = [], list2 = []
Output: []

Example 3:

Input: list1 = [], list2 = [0]
Output: [0]

Constraints:

  • The number of nodes in both lists is in the range [0, 50].
  • -100 <= Node.val <= 100
  • Both list1 and list2 are sorted in non-decreasing order.

Plan Solution

  1. Set two pointers: one for the head of the new linked list and one for the current position in the new linked list.
  2. While both list1 and list2 have at least one node, move the pointer one step at a time.
  3. If the value of the node from list1 is smaller than the value of the node from list2, set the next node to be the node from list1.
  4. Return the next node of the head.

Code

# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
class Solution:
    def mergeTwoLists(self, list1: Optional[ListNode], list2: Optional[ListNode]) -> Optional[ListNode]:

        dummy = ListNode(0)
        current = dummy

        while list1 and list2:
            if list1.val < list2.val:
                current.next = list1
                list1 = list1.next
            else:
                current.next = list2
                list2 = list2.next
            current = current.next
        
        current.next = list1 or list2

        return dummy.next

Result

  • Time Complexity : O(n)
  • Space Complexity : O(1)
profile
μ•Œμ­λ‹¬μ­ν˜€μš”

0개의 λŒ“κΈ€