【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;
    }
};
相关推荐
郝学胜_神的一滴7 分钟前
Qt 高级开发 026:QTabWidget御道,从筑基到化境
c++·qt
apocelipes38 分钟前
GNU GCC 多版本函数扩展
c语言·c++·linux编程
代码中介商1 小时前
C++完美转发与引用折叠全解析
开发语言·c++
雪度娃娃1 小时前
ASIO异步通信——多线程模型
开发语言·网络·c++·php
运筹vivo@2 小时前
LeetCode 2574. 左右元素和的差值
算法·leetcode·职场和发展·每日一题
一只齐刘海的猫3 小时前
【Leetcode】移动零
算法·leetcode·职场和发展
人道领域3 小时前
【LeetCode刷题日记】131.分割回文串,动态规划优化
java·开发语言·leetcode
王老师青少年编程4 小时前
信奥赛C++提高组csp-s之搜索进阶(迭代加深IDDFS)
c++·csp·信奥赛·csp-s·提高组·iddfs·埃及分数
liulilittle4 小时前
我从 BBRv1 到 KCC 的思考
网络·c++·tcp/ip·计算机网络·tcp·bbr·通信
落羽的落羽4 小时前
【项目】JsonRpc框架——开发实现1(细节功能、字段定义、抽象层、具象层)
linux·服务器·网络·c++·人工智能·算法·机器学习