算法面试题:合并两个有序链表

描述:给定两个按非递减顺序排列的链表,合并两个链表,并将结果按非递减顺序排列。

例如:

cpp 复制代码
# 链表 1: 1 -> 2 -> 4
# 链表 2: 1 -> 3 -> 4

合并后的链表应该是:1 -> 1 -> 2 -> 3 -> 4 -> 4

要求:

实现一个函数 merge_two_lists(l1, l2),其中 l1 和 l2 分别为两个有序链表的头结点。

函数应该返回合并后的有序链表的头结点。

实现:

cpp 复制代码
class ListNode:
    def __init__(self, val=0, next=None):
        self.val = val
        self.next = next

def merge_two_lists(l1, l2):
    # 创建一个虚拟头结点,方便操作
    dummy = ListNode()
    current = dummy
    
    # 遍历两个链表
    while l1 and l2:
        # 比较当前两个节点的值,将较小的节点连接到新链表中
        if l1.val < l2.val:
            current.next = l1
            l1 = l1.next
        else:
            current.next = l2
            l2 = l2.next
        current = current.next
    
    # 处理剩余的节点
    if l1:
        current.next = l1
    elif l2:
        current.next = l2
    
    # 返回合并后的链表头结点
    return dummy.next

# 测试
l1 = ListNode(1, ListNode(2, ListNode(4)))
l2 = ListNode(1, ListNode(3, ListNode(4)))
result = merge_two_lists(l1, l2)

# 打印合并后的链表值
while result:
    print(result.val, end=" -> ")
    result = result.next
# 输出:1 -> 1 -> 2 -> 3 -> 4 -> 4

这个算法使用了双指针,遍历两个有序链表,比较当前节点的值,将较小的节点连接到新链表中。最后处理剩余的节点,并返回合并后的链表头结点。

相关推荐
蒙奇D索大34 分钟前
【数据结构】图论最短路径算法深度解析:从BFS基础到全算法综述
数据结构·算法·图论·广度优先·图搜索算法
trouvaille35 分钟前
哈希数据结构的增强
算法·go
我不是小upper1 小时前
L1和L2核心区别 !!--part 2
人工智能·深度学习·算法·机器学习
liujing102329292 小时前
Day09_刷题niuke20250609
java·c++·算法
不7夜宵2 小时前
力扣热题100 k个一组反转链表题解
算法·leetcode·链表
蒟蒻小袁3 小时前
力扣面试150题--课程表
算法·leetcode·面试
闻缺陷则喜何志丹3 小时前
【动态规划】B4336 [中山市赛 2023] 永别|普及+
c++·算法·动态规划·洛谷
不二狗4 小时前
每日算法 -【Swift 算法】电话号码字母组合
开发语言·算法·swift
AL流云。4 小时前
【优选算法】分治
数据结构·算法·leetcode·排序算法
行驶5 小时前
数据结构 - 栈与队列
数据结构