LeetCode如何合并两个有序链表
发表于:2024-12-13 作者:千家信息网编辑
千家信息网最后更新 2024年12月13日,这篇文章将为大家详细讲解有关LeetCode如何合并两个有序链表,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、题目描述将两个升序链表合并为一个新的升序链表并返回
千家信息网最后更新 2024年12月13日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安全错误
数据库的锁怎样保障安全
万方医学论文数据库
重庆网络安全ppt
公安网络安全会议再强调
大连的dns服务器
安卓服务器端开发
湖南软件开发接工程程叫什么
网络安全问题及对策论文目录
网络安全三要素cia
如何改变数据库保存路径
网络安全教育主题队会教案
轻量级服务器手机管理
本地远程服务器
基层宣传网络安全新闻稿
智德网络技术
ajax创建数据库
香港丞芮网络技术是真的吗
wps 数据库处理
全国三级网络技术题库
红色讲堂数据库开通试用
服务器小游戏丧尸围城
ssh如何断开连接服务器
计算机网络技术去当兵有用吗
国产化服务器厂家供应
济宁联想服务器代理零售商
c 中怎么获取数据库时间
深圳软件开发公司图片
dbf数据库出错
上海精益管理软件开发
台州智商网络技术
我的世界服务器下午有延迟