LeetCode如何合并两个有序链表
发表于:2025-12-02 作者:千家信息网编辑
千家信息网最后更新 2025年12月02日,这篇文章将为大家详细讲解有关LeetCode如何合并两个有序链表,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、题目描述将两个升序链表合并为一个新的升序链表并返回
千家信息网最后更新 2025年12月02日LeetCode如何合并两个有序链表
这篇文章将为大家详细讲解有关LeetCode如何合并两个有序链表,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
一、题目描述
将两个升序链表合并为一个新的升序链表并返回,新链表是通过拼接给定的两个链表的所有节点组成的,比如:
输入:1->2->4, 1->3->4 输出:1->1->2->3->4->4
二、解题思路
2.1 迭代法
使用循环迭代的方法,依次找出较小的节点链接起来即可:
比较 l1 和 l2 当前节点值的大小 将较小的节点链接到 l3 尾部 l1 或 l2 指针后移一位 l3 指针后移一位 循环结束:l1 和 l2 其中一个遍历到尾部 将未遍历完的节点全部链接到 l3 尾部 返回保存的 l3 头指针 head->next
class Solution {
public:
ListNode* mergeTwoLists(ListNode* l1, ListNode* l2) {
// 1. 升序链表 l3
ListNode *l3 = new ListNode(0);
// 2. 保存头指针用于返回结果
ListNode *head = l3;
while (l1 && l2) {
// 3. 选择较小的节点连接到 l3 尾部
if (l1->val <= l2->val) {
l3->next = l1;
l1 = l1->next;
} else {
l3->next = l2;
l2 = l2->next;
}
l3 = l3->next;
}
// 将多余的 l1 或者 l2 节点直接链接到 l3 尾部
l3->next = (l1 == nullptr ? l2 : l1);
return head->next;
}
};
复杂度分析
时间复杂度:O(m + n),循环的次数等于 2 个链表的总长度 m + n 空间复杂度:O(1),使用的变量内存为常数级别
2.2 递归法
递归法要注意递归表达式和循环结束条件:
当 l1 为空,返回 l2 当 l2 为空,返回 l1 l1 和 l2 都不为空,比较节点 val 将较小的节点链接上,并递归调用函数来确定下一个链接的节点
递归法不是很好理解,建议用 vs 调试看下内存。
class Solution {
public:
ListNode* mergeTwoLists(ListNode* l1, ListNode* l2) {
// 1. 递归结束条件
if (l1 == nullptr)
return l2;
// 2. 递归结束条件
if (l2 == nullptr)
return l1;
// 3. 递归表达式
if (l1->val <= l2->val) {
l1->next = mergeTwoLists(l1->next, l2);
return l1;
} else {
l2->next = mergeTwoLists(l1, l2->next);
return l2;
}
}
};
复杂度分析
时间复杂度:O(m + n),每次递归都会添加一个链表节点,最终会递归 m + n 次 空间复杂度:递归的过程中,会将全部 m + n 个节点都保存一次在递归调用栈中
关于"LeetCode如何合并两个有序链表"这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
节点
递归
复杂
复杂度
链接
尾部
两个
指针
循环
升序
条件
篇文章
有序
内存
时间
更多
空间
表达式
分析
后移
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
加速软件开发遗传及应用
软件开发工程师熬夜吗
网络安全宣传周 效应
网络安全人员培养x
网络安全领导小组 学校
j计算机网络安全知识
联想万全t468塔式服务器
杭州4年软件开发工资
数据库中的use是什么意思
生活中用到网络安全技术的地方
北京中国网络技术有限公司
兰州网络安全保障线上学习
国家兽药基础数据库网址下载
怎么将项目部署到服务器上呢
内蒙古诚信网络技术服务商家
网络安全违规外联通报
后台数据库的引入
郑州平台软件开发高新区
为什么执行数据库不明确
软件开发明细及工作量评估
网络安全类专项
美团网软件开发
福建推荐的软件开发技术指导
dw服务器lin
东营网络技术企业
织梦cms数据库自动备份
为什么计算机里找不到数据库服务
数据库 公开课
软件开发及平台售后服务
中国电科软件开发技术水平