21. 合并两个有序链表

21. 合并两个有序链表

你的 mergeTwoLists 函数用于合并两个已排序的链表。代码中存在缩进错误和一些细节问题。以下是修正后的代码以及详细注释:

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

def mergeTwoLists(self, l1: ListNode, l2: ListNode) -> ListNode:
    # 创建一个哑节点(dummy node)并初始化指针
    dummy = ListNode(0)
    temp = dummy

    # 遍历两个链表,直到其中一个为空
    while l1 and l2:
        if l1.val <= l2.val:
            temp.next = l1
            l1 = l1.next
        else:
            temp.next = l2
            l2 = l2.next
        temp = temp.next

    # 将剩余的节点连接到结果链表
    temp.next = l1 if l1 else l2

    # 返回合并后的链表头节点
    return dummy.next

详细注释

  1. 定义链表节点类

    python 复制代码
    class ListNode:
        def __init__(self, val=0, next=None):
            self.val = val
            self.next = next
  2. 合并两个有序链表的函数

    python 复制代码
    def mergeTwoLists(self, l1: ListNode, l2: ListNode) -> ListNode:
  3. 创建哑节点

    python 复制代码
    dummy = ListNode(0)
    temp = dummy
    • 创建一个哑节点 dummy,并初始化指针 temp 指向 dummy。哑节点用于简化链表操作,最终返回合并后的链表头节点。
  4. 遍历两个链表,直到其中一个为空

    python 复制代码
    while l1 and l2:
        if l1.val <= l2.val:
            temp.next = l1
            l1 = l1.next
        else:
            temp.next = l2
            l2 = l2.next
        temp = temp.next
    • 比较 l1l2 的当前节点值,将较小值的节点连接到结果链表 tempnext,并移动相应链表的指针。
    • 移动 temp 指针到下一个节点。
  5. 连接剩余的节点

    python 复制代码
    temp.next = l1 if l1 else l2
    • 如果 l1l2 还有剩余的节点,直接连接到 tempnext
  6. 返回合并后的链表头节点

    python 复制代码
    return dummy.next
    • 返回哑节点 dummynext,即合并后的链表头节点。

示例

假设链表 l11 -> 2 -> 4,链表 l21 -> 3 -> 4

  1. 初始状态

    • dummy: 0 -> None
    • temp 指向 dummy
  2. 第一次比较

    • l1.val = 1, l2.val = 1
    • l1 连接到 temp.next,移动 l1 到下一个节点
    • dummy: 0 -> 1 -> 2 -> 4
    • temp: 1 -> 2 -> 4
  3. 第二次比较

    • l1.val = 2, l2.val = 1
    • l2 连接到 temp.next,移动 l2 到下一个节点
    • dummy: 0 -> 1 -> 1 -> 3 -> 4
    • temp: 1 -> 1 -> 3 -> 4
  4. 继续比较并合并

    • 继续上述过程,直到 l1l2 中一个为空
  5. 连接剩余的节点

    • 将剩余的 l1l2 连接到 temp.next
    • 最终 dummy 连接的链表为 0 -> 1 -> 1 -> 2 -> 3 -> 4 -> 4
  6. 返回合并后的链表头节点

    • 返回 dummy.next1 -> 1 -> 2 -> 3 -> 4 -> 4

通过这种方式,可以将两个有序链表合并为一个新的有序链表。

相关推荐
papership8 小时前
【入门级-数据结构-3、特殊树:完全二叉树的数组表示法】
数据结构·算法·链表
smj2302_796826529 小时前
解决leetcode第3911题.移除子数组元素后第k小偶数
数据结构·python·算法·leetcode
山甫aa9 小时前
差分数组 ----- 从零开始的数据结构
数据结构
早日退休!!!9 小时前
《数据结构选型指南》笔记
数据结构·数据库·oracle
Beginner x_u9 小时前
链表专题:JS 实现原理与高频算法题总结
javascript·算法·链表
丑八怪大丑9 小时前
Java数据结构与集合源码
数据结构
一个爱编程的人18 小时前
一个数是不是素数
数据结构·算法
忡黑梨18 小时前
eNSP_从直连到BGP全网互通
c语言·网络·数据结构·python·算法·网络安全
地球资源数据云19 小时前
1900-2023年中国物种分布点位矢量数据集
大数据·数据结构·数据库·数据仓库·人工智能
AI人工智能+电脑小能手19 小时前
【大白话说Java面试题】【Java基础篇】第20题:HashMap在计算index的时候,为什么要对数组长度做减1操作
java·开发语言·数据结构·后端·面试·哈希算法·hash-index