C++ | Leetcode C++题解之第21题合并两个有序链表

题解:

题解:

cpp 复制代码
class Solution {
public:
    ListNode* mergeTwoLists(ListNode* l1, ListNode* l2) {
        ListNode* preHead = new ListNode(-1);

        ListNode* prev = preHead;
        while (l1 != nullptr && l2 != nullptr) {
            if (l1->val < l2->val) {
                prev->next = l1;
                l1 = l1->next;
            } else {
                prev->next = l2;
                l2 = l2->next;
            }
            prev = prev->next;
        }

        // 合并后 l1 和 l2 最多只有一个还未被合并完,我们直接将链表末尾指向未合并完的链表即可
        prev->next = l1 == nullptr ? l2 : l1;

        return preHead->next;
    }
};
相关推荐
Ronin3053 小时前
持久化数据管理中心模块
开发语言·c++·rabbitmq·gtest
sycmancia3 小时前
C++——强制类型转化、const的理解
开发语言·c++
我在人间贩卖青春3 小时前
C++之面向对象编程多文件文件示例
c++
燃于AC之乐3 小时前
深入解剖STL deque:从源码剖析到容器适配器实现
开发语言·c++·stl·源码剖析·容器实现
MSTcheng.3 小时前
【C++】C++异常
java·数据库·c++·异常
草莓熊Lotso4 小时前
Linux 文件描述符与重定向实战:从原理到 minishell 实现
android·linux·运维·服务器·数据库·c++·人工智能
历程里程碑4 小时前
Linux22 文件系统
linux·运维·c语言·开发语言·数据结构·c++·算法
YGGP5 小时前
【Golang】LeetCode 128. 最长连续序列
leetcode
在路上看风景11 小时前
19. 成员初始化列表和初始化对象
c++
zmzb010311 小时前
C++课后习题训练记录Day98
开发语言·c++