两个链式存储的线性表LA和LB,其元素均按从小到大的顺序排列,编写一个算法,将他们合并为一个递增的链表,要求利用原表
时间: 2024-11-15 16:28:56 浏览: 19
为了合并两个已排序的链表LA和LB,并保持递增顺序,你可以创建一个新的链表LC,然后遍历这两个链表。对于每个节点,我们将在新链表中插入当前较小的节点,直到其中一个链表遍历完。以下是合并过程的一个简单的伪代码描述:
```python
def merge_sorted_lists(LA, LB):
# 创建头节点和指针
LC = ListNode(0) # 新链表的头节点
LCPtr = LC # 指向新链表的指针
while LA and LB: # 当LA和LB都还有节点
if LA.val < LB.val: # 如果LA的值小于LB的值
LCPtr.next = LA # 将LA的节点添加到新链表
LA = LA.next # 移动LA的指针
else: # 否则
LCPtr.next = LB # 将LB的节点添加到新链表
LB = LB.next # 移动LB的指针
LCPtr = LCPtr.next # 总指针移动到下一个节点
# 添加剩余的链表(如果有的话)
if LA is not None: # 如果LA还没遍历完
LCPtr.next = LA
elif LB is not None: # 如果LB还没遍历完
LCPtr.next = LB
return LC.next # 返回合并后的链表头节点
# 示例中的数据结构:
class ListNode:
def __init__(self, val=0, next=None):
self.val = val
self.next = next
```
阅读全文