LeetCode Hot100刷题——合并两个有序链表

21.合并两个有序链表

1. 题目描述

将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。

示例 1:

复制代码
输入:l1 = [1,2,4], l2 = [1,3,4]
输出:[1,1,2,3,4,4]

示例 2:

复制代码
输入:l1 = [], l2 = []
输出:[]

示例 3:

复制代码
输入:l1 = [], l2 = [0]
输出:[0]

提示:

  • 两个链表的节点数目范围是 [0, 50]
  • -100 <= Node.val <= 100
  • l1l2 均按 非递减顺序 排列

2. 完整思路分析

**题目要求:**合并两个升序链表为一个新的升序链表,要求通过直接拼接节点实现(不创建新节点)。

核心思路: 使用双指针遍历两个链表,比较节点值大小,将较小值的节点链接到新链表上。

  • 关键技巧:
    • **哨兵节点(Dummy Node):**简化链表头部的特殊处理,避免空指针问题。
    • **指针移动策略:**始终将较小值的节点接入新链表,并移动对应链表的指针。
    • **剩余链表处理:**当某一链表遍历完后,直接将另一链表的剩余部分接入新链表。
  • 边界处理:
    • ​​​​​​​两个链表均为空时,返回空链表。
    • 其中一个链表为空时,直接返回另一个链表。

**时间复杂度:**O(m+n),其中m和n分别是两个链表的长度。

**空间复杂度:**O(1),仅使用常熟级别的额外空间。


3. 解题过程

步骤分析:

  1. 创建一个哨兵节点(dummy),用于简化边界条件处理,它的next指向合并后链表的头节点。
  2. 使用一个指针current指向当前新链表的最后一个节点,初始时指向dummy。
  3. 使用两个指针分别指向两个链表的当前节点,初始时分别为l1和l2的头节点。
  4. 循环比较两个链表当前节点的值,将较小值的节点接在current后面,并移动该链表的指针和current指针。
  5. 当其中一个链表遍历完时,将另一个链表的剩余部分直接接在current后面(因为链表本身就是有序的)。
  6. 返回dummy.next,即为合并后的链表头节点。

程序代码

java 复制代码
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public ListNode mergeTwoLists(ListNode list1, ListNode list2) {
        // 创建哨兵节点,简化链表头处理
        ListNode dummy = new ListNode(-1);
        ListNode current = dummy;

        // 双指针遍历两个链表
        while (list1 != null && list2 != null) {
            if (list1.val <= list2.val) {
                // 将较小节点接入新链表
                current.next = list1;
                // 移动指针
                list1 = list1.next;
            } else {
                current.next = list2;
                list2 = list2.next;
            }
            // 更新新链表指针
            current = current.next;
        }
        // 处理剩余链表部分
        current.next = (list1 != null) ? list1 : list2;

        // 返回新链表的实际头节点
        return dummy.next;
    }
}
  • 初始化哨兵节点
    • ​​​​​​​创建dummy节点(值为-1),其next指向最终结果链表的头部
    • current指针初始指向dummy,用于构建新链表
  • 双指针遍历比较
    • ​​​​​​​当 list1 和 list2 均不为空时循环:
      • 比较 list1.val 和 list2.val
      • 将较小值的节点链接到current.next
      • 移动较小值节点所在链表的指针(list1或list2后移)
      • current指针后移,保持指向新链表末尾
  • 处理剩余链表
    • ​​​​​​​循环结束后,最多只有一个链表非空
    • 直接将非空链表链接到current.next
  • 返回结果
    • ​​​​​​​返回dummy.next(哨兵节点的下一个节点即新链表的实际头节点)
相关推荐
程序猿小D19 分钟前
Java项目:基于SSM框架实现的校园活动资讯网管理系统【ssm+B/S架构+源码+数据库+毕业论文+远程部署】
java·数据库·mysql·spring·毕业设计·ssm框架·校园活动
麦兜*20 分钟前
大模型时代,Transformer 架构中的核心注意力机制算法详解与优化实践
jvm·后端·深度学习·算法·spring·spring cloud·transformer
阿华的代码王国24 分钟前
【Android】PopupWindow实现长按菜单
android·xml·java·前端·后端
coding随想25 分钟前
算法界的“达摩克利斯之剑”——NP完全性理论
算法
找不到、了28 分钟前
关于MyBatis 的懒加载(Lazy Loading)机制
java·mybatis
啃火龙果的兔子1 小时前
快速搭建Java服务指南
java·开发语言
未来之窗软件服务1 小时前
智慧收银系统开发进销存库存统计,便利店、水果店、建材与家居行业的库存汇总管理—仙盟创梦IDE
java·开发语言·ide·进销存·仙盟创梦ide·东方仙盟·收银台
CodeCraft Studio1 小时前
国产化PDF处理控件Spire.PDF教程:Java 提取 PDF 图片,高质量提取与图片过滤技巧
java·python·pdf·国产化·文档处理·spire·pdf图片提取
秋难降1 小时前
栈:从基础概念到实战解题(详细)
数据结构·算法·排序算法
归云鹤1 小时前
QT信号和槽怎么传输自己定义的数据结构
开发语言·数据结构·qt