- 标签:递归、链表
- 难度:简单
描述:给定两个升序链表的头节点 list1
和 list2
。
要求:将其合并为一个升序链表。
说明:
- 两个链表的节点数目范围是
$[0, 50]$ 。 -
$-100 \le Node.val \le 100$ 。 -
list1
和list2
均按 非递减顺序 排列
示例:
- 示例 1:
输入:list1 = [1,2,4], list2 = [1,3,4]
输出:[1,1,2,3,4,4]
- 示例 2:
输入:list1 = [], list2 = []
输出:[]
利用归并排序的思想,具体步骤如下:
- 使用哑节点
dummy_head
构造一个头节点,并使用curr
指向dummy_head
用于遍历。 - 然后判断
list1
和list2
头节点的值,将较小的头节点加入到合并后的链表中。并向后移动该链表的头节点指针。 - 然后重复上一步操作,直到两个链表中出现链表为空的情况。
- 将剩余链表链接到合并后的链表中。
- 将哑节点
dummy_dead
的下一个链节点dummy_head.next
作为合并后有序链表的头节点返回。
class Solution:
def mergeTwoLists(self, list1: Optional[ListNode], list2: Optional[ListNode]) -> Optional[ListNode]:
dummy_head = ListNode(-1)
curr = dummy_head
while list1 and list2:
if list1.val <= list2.val:
curr.next = list1
list1 = list1.next
else:
curr.next = list2
list2 = list2.next
curr = curr.next
curr.next = list1 if list1 is not None else list2
return dummy_head.next
- 时间复杂度:$O(n)$。
- 空间复杂度:$O(1)$。