【leetcode面试经典150题】59. 合并两个有序链表(C++)

【leetcode面试经典150题】专栏系列将为准备暑期实习生以及秋招的同学们提高在面试时的经典面试算法题的思路和想法。本专栏将以一题多解和精简算法思路为主,题解使用C++语言。(若有使用其他语言的同学也可了解题解思路,本质上语法内容一致)

【题目描述】

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

【示例一】

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

【示例二】

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

【示例三】

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

【提示及数据范围】

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

【代码】

cpp 复制代码
// 方法一:递归

class Solution {
public:
    ListNode* mergeTwoLists(ListNode* l1, ListNode* l2) {
        if (l1 == nullptr) {
            return l2;
        } else if (l2 == nullptr) {
            return l1;
        } else if (l1->val < l2->val) {
            l1->next = mergeTwoLists(l1->next, l2);
            return l1;
        } else {
            l2->next = mergeTwoLists(l1, l2->next);
            return l2;
        }
    }
};


// 方法二:迭代
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;
    }
};
相关推荐
owde2 分钟前
深入 C++ 线程库:从创建到同步的探索之旅
开发语言·c++·thread·lock
jz_ddk5 分钟前
[实战]多天线空域抗干扰技术:原理、数学推导与工程仿真(完整仿真代码)
python·算法·毕业设计·信号处理
Determined_man9 分钟前
Mybatis-plus queryWrapper的使用
数据结构·数据库
曲鸟25 分钟前
大环境不好,测试人员该如何快速进阶
前端·后端·面试
吾名招财30 分钟前
基于机器视觉的多孔零件边缘缺陷检测(源码C++、opencv、凸包、凸缺陷检测)
c++·opencv·机器视觉·凸包·凸缺陷
T0uken32 分钟前
【C++】信号槽与事件总线的轻量实现
开发语言·c++
Moment40 分钟前
你写的网站安全吗?这四个攻击方式正在悄悄盯上你
前端·后端·面试
lvchaoq42 分钟前
图解力扣回溯及剪枝问题的模板应用
leetcode·深度优先·剪枝·回溯·递归
dog shit1 小时前
蓝桥杯第十一届省赛C++B组真题解析
算法
狂炫一碗大米饭1 小时前
vue面试高频考题----computed和watch的区别❓
前端·vue.js·面试