【Hot 100 刷题计划】 LeetCode 21. 合并两个有序链表 | C++ 经典迭代与 Dummy 技巧

LeetCode 21. 合并两个有序链表

📌 题目描述

题目级别:简单

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

  • 示例 1:
    输入:l1 = [1,2,4], l2 = [1,3,4]
    输出:[1,1,2,3,4,4]

💡 破题思路:Dummy 节点与拉链法

合并两个有序链表的过程,非常像我们在给衣服拉拉链

拉链的左右两排锯齿就是 list1list2,拉链头就是我们的比较逻辑,谁比较小,谁就先卡进拉链的轨道里。

核心高光点 (Dummy Node):

合并链表时,最大的痛点是**"第一个节点到底选谁"。如果不做特殊处理,就必须在循环外写一堆 if (list1->val < list2->val) 来决定头指针。
为了优雅地避开这个问题,我们可以人为制造一个
虚拟头节点 (dummy)**!

这样一来,无论是哪个链表的节点,统统当做小弟,往 dummy 屁股后面接就行了。最后返回结果时,直接返回 dummy->next,深藏功与名。


💻 C++ 代码实现 (迭代法最优解)

cpp 复制代码
class Solution {
public:
    ListNode* mergeTwoLists(ListNode* list1, ListNode* list2) {
        // 创建一个虚拟头节点,避免处理合并后链表头为空的边界情况
        ListNode* dummy = new ListNode();
        ListNode* cur = dummy;

        // 当两个链表都还没走完时,互相比较,谁小谁上
        while (list1 && list2)
        {
            if (list1->val <= list2->val)
            {
                cur->next = list1;
                list1 = list1->next;
            }
            else 
            {
                cur->next = list2;
                list2 = list2->next;
            }
            // 拼接好一个节点后,当前指针往后挪一步,准备接下一个
            cur = cur->next;
        }

        // 循环结束后,肯定有一个链表先空了
        // 把另一个还没空的链表,剩下的一大串直接挂在末尾即可
        cur->next = list1 ? list1 : list2;

        return dummy->next;
    }
};
相关推荐
To_OC6 分钟前
LC 208 实现 Trie 前缀树:曾被名字劝退,写完发现是送分题
javascript·算法·leetcode
BadBadBad__AK2 小时前
线段树维护区间 k 次方和
c++·数学·算法·stl
卷无止境14 小时前
Eigen 库如何借助 OpenMP 加速计算
c++·后端
卷无止境14 小时前
OpenMPI、MPICH 与 OpenMP:关系、核心概念与架构全解
c++·后端
To_OC1 天前
LC 994 腐烂的橘子:人人都说是 BFS 入门题,我却写了三遍才过
javascript·算法·leetcode
To_OC1 天前
LC 200 岛屿数量:经典 DFS 入门题,我第一次写居然连方向都搞错了
javascript·算法·leetcode
郝学胜_神的一滴2 天前
CMake 30:循环语法全解|foreach_while双循环精讲、迭代技巧与实战避坑指南
c++·cmake
To_OC2 天前
LC 128 最长连续序列:别上来就排序,O (n) 解法才是这题的灵魂
javascript·算法·leetcode
卷无止境4 天前
C++ 的Eigen 库全解析
c++
卷无止境4 天前
现代 C++特性大盘点:一门脱胎换骨的老语言
c++·后端