【刷题记录】21. 合并两个有序链表
一、题目描述
来源:力扣(LeetCode)
将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。
示例 1:
复制代码
示例 2:
复制代码
示例 3:
复制代码
提示:
两个链表的节点数目范围是 [0, 50]
-100 <= Node.val <= 100
l1 和 l2 均按 非递减顺序 排列
二丶思路分析
双指针解法
这道题类似 【刷题记录】2. 两数相加 在上题中,是给出两个链表,对节点中的数字依次相加,合成一个新的链表,而在此题中,则是直接比较(因为l1 和 l2 均按 非递减顺序 排列
)两个链表中节点的值,合成一个新的链表即可。
三、代码实现
复制代码
复杂度分析
时间复杂度:对两条链表扫描一遍。复杂度为
m
,n
为两个链表的长度空间复杂度:
运行结果
总结
这道题目也是一个通过双指针对链表进行处理的一个变形题目。理解这种思路,我们可以在很多地方利用这个来帮助我们处理相应的问题。
继续加油~
版权声明: 本文为 InfoQ 作者【WangNing】的原创文章。
原文链接:【http://xie.infoq.cn/article/d1eb84b48d3ffd6edc4dd6ab4】。
本文遵守【CC-BY 4.0】协议,转载请保留原文出处及本版权声明。
评论