21. 合并两个有序链表

21. 合并两个有序链表 - 力扣(LeetCode)

简单

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

示例 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 均按 非递减顺序 排列

📝 核心笔记:合并两个有序链表 (递归法)

1. 核心思想 (一句话总结)

"谁小谁当头,剩下的任务交给下级。"

比较两个链表的头节点,数值小的那个作为当前的头,然后它的 next 指向剩余部分合并后的结果(递归调用)。

💡 直观理解:

只要选出了当前最小的节点,我就不用管剩下的怎么排了,直接把剩下的任务"外包"给递归函数,等它排好序返回给我接上就行。

2. 算法流程 (三步走)
  1. 判空 (终止条件):
    • 如果 list1 空了,没得比了,直接接上 list2
    • 如果 list2 空了,直接接上 list1
  1. 选头 (比较大小):
    • 看谁更小。假设 list1 小,那 list1 就是老大。
  1. 连接 (递归):
    • list1 的后面 (next) 应该接谁?接 "list1剩余部分" 和 "list2完整部分" 合并后的结果。
🔍 代码回忆清单
复制代码
// 题目:LC 21. 合并两个有序链表
class Solution {
    public ListNode mergeTwoLists(ListNode list1, ListNode list2) {
        // 1. 终止条件 (底线)
        // 只要有一条链表空了,就直接返回另一条 (另一条也是有序的,直接接上)
        if (list1 == null) return list2; 
        if (list2 == null) return list1;

        // 2. 递归主逻辑 (选老大)
        if (list1.val < list2.val) {
            // list1 小,list1 当头
            // list1 的下家是谁? -> 是 (list1.next 和 list2) PK 出来的赢家
            list1.next = mergeTwoLists(list1.next, list2);
            return list1; // 别忘了返回当前的头
        } else {
            // list2 小 (或相等),list2 当头
            // list2 的下家是谁? -> 是 (list1 和 list2.next) PK 出来的赢家
            list2.next = mergeTwoLists(list1, list2.next);
            return list2;
        }
    }
}
⚡ 快速复习 CheckList (易错点)
  • \] **终止条件写全了吗?** 必须处理 `list1 == null` 和 `list2 == null` 两种情况。

  • \] **空间复杂度?** 递归法是 $O(N+M)$,因为消耗了栈空间。如果面试官要求 $O(1)$ 空间,需要改用**迭代法** (Dummy Node)。

🖼️ 场景联想

拉拉链。

拉链的锁头就是递归函数。

它看着左边齿轮 (list1) 和右边齿轮 (list2),哪个位置低(数值小)就先把哪个齿轮扣进去,然后往上移一格,继续看下一个。

相关推荐
迷藏4945 分钟前
**发散创新:基于Rust实现的开源合规权限管理框架设计与实践**在现代软件架构中,**权限控制(RBAC)** 已成为保障
java·开发语言·python·rust·开源
黎阳之光20 分钟前
黎阳之光:视频孪生领跑者,铸就中国数字科技全球竞争力
大数据·人工智能·算法·安全·数字孪生
skywalker_1126 分钟前
力扣hot100-3(最长连续序列),4(移动零)
数据结构·算法·leetcode
6Hzlia27 分钟前
【Hot 100 刷题计划】 LeetCode 17. 电话号码的字母组合 | C++ 回溯算法经典模板
c++·算法·leetcode
wfbcg1 小时前
每日算法练习:LeetCode 209. 长度最小的子数组 ✅
算法·leetcode·职场和发展
_日拱一卒1 小时前
LeetCode:除了自身以外数组的乘积
数据结构·算法·leetcode
wuxinyan1231 小时前
Java面试题47:一文深入了解Nginx
java·nginx·面试题
计算机安禾1 小时前
【数据结构与算法】第36篇:排序大总结:稳定性、时间复杂度与适用场景
c语言·数据结构·c++·算法·链表·线性回归·visual studio
新知图书1 小时前
搭建Spring Boot开发环境
java·spring boot·后端
冰河团队1 小时前
一个拉胯的分库分表方案有多绝望?整个部门都在救火!
java·高并发·分布式数据库·分库分表·高性能