python 假设有两个按元素值递增次序排列的线性表,均以单链表形式存储。请编写算法将这两个单链表归并为一个按元素值升序排列的单链表。
时间: 2023-06-11 12:06:33 浏览: 127
可以使用双指针法,从两个单链表的头节点开始比较,将较小的节点依次添加到新的单链表中,直到其中一个单链表为空,然后将另一个单链表的剩余部分直接添加到新单链表的末尾。
具体实现如下:
```python
class ListNode:
def __init__(self, val=0, next=None):
self.val = val
self.next = next
def mergeTwoLists(l1: ListNode, l2: ListNode) -> ListNode:
dummy = ListNode(-1) # 创建一个虚拟头节点
cur = dummy # cur 指向新链表的最后一个节点
while l1 and l2:
if l1.val <= l2.val:
cur.next = l1
l1 = l1.next
else:
cur.next = l2
l2 = l2.next
cur = cur.next
# 将剩余的节点直接添加到新链表的末尾
if l1:
cur.next = l1
if l2:
cur.next = l2
return dummy.next # 返回新链表的头节点
```
测试代码:
```python
# 创建两个有序链表
l1 = ListNode(1, ListNode(2, ListNode(4)))
l2 = ListNode(1, ListNode(3, ListNode(4)))
# 将两个链表合并
merged_list = mergeTwoLists(l1, l2)
# 输出合并后的链表
while merged_list:
print(merged_list.val, end=' ')
merged_list = merged_list.next
```
输出结果:`1 1 2 3 4 4`
阅读全文