LeetCode如何合并两个有序链表
发表于:2025-02-03 作者:千家信息网编辑
千家信息网最后更新 2025年02月03日,这篇文章将为大家详细讲解有关LeetCode如何合并两个有序链表,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、题目描述将两个升序链表合并为一个新的升序链表并返回
千家信息网最后更新 2025年02月03日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安全错误
数据库的锁怎样保障安全
杭州速保网络技术有限公司介绍
虚拟机天龙八部数据库连接失败
与嵌入式系统相关的软件开发
万方医学数据库论文怎么查
性能优化数据库查询
对软件开发有什么想法
德国联邦政府网络安全
excel引用固定数据库
哪些是杀毒软件开发商
主键定位删除数据库
网络安全网络攻击技术ppt
工业控制网络技术 第2版
计算机网络技术应用教学
数据库导入使用的命令是
迪哥服务器怎么进去
重生之之互联网科技帝国
网络技术员年终工作总
数据库改了密码 网站进不去
网络安全有什么考试题
27个国家网络安全
用指令连接数据库
中国科技经济数据库怎么查询
微信服务器记录吗
网络安全公益歌曲
交行软件开发北京中心待遇
无线网显示暂时无法连接服务器
军训网络安全讲座作文
河北正规软件开发多少钱
网络安全与执法专业有前景吗
如何不停的从服务器下载东西