Leetcode打卡 | No.23 合并 k 个有序链表

简介: 欢迎和小詹一起定期刷leetcode,每周一和周五更新一题,每一题都吃透,欢迎一题多解,寻找最优解!这个记录帖哪怕只有一个读者,小詹也会坚持刷下去的!

No.23  合并 k 个有序链表

合并 k 个排序链表,返回合并后的排序链表。请分析和描述算法的复杂度。

示例:

输入:[
 1->4->5,
 1->3->4,
 2->6
]输出: 1->1->2->3->4->4->5->6

这一题可以看作是前边第 21 题的升级版 ,小伙伴们可以温故一下之前类似的题目 :

Leetcode打卡 | No.21 合并两个有序链表

这里是 k 个有序链表 ,小詹看到第一反应是直接递归使用前边合并两个有序链表的思路 ,对 ,完全没毛病的 。然后参考答案里是类似的 ,只不过合并的方式不一样 ,这里采取的是两两合并的方式 ,过程见下图 :

0.jpg


这里可以很清晰的看懂思路 ,实现代码如下 :

1.jpg


这种方式的结果大概是 beat 65% 左右 ,还有一种看起来比较复杂的办法 ,但是结果却很赞 。大体思路分为三步 :

  1. 创建一个列表
  2. 将所有链表的元素值 append 进列表
  3. 进行排序 ,之后再转换为链表结构

代码实现如下 :

2.jpg


题目中要求描述下算法复杂度 ,这里以第二种 "三步曲" 的算法为例描述 ,另一方法读者自行尝试下哦 。

  1. 时间复杂度 ,分为三步分别考虑 ,首先将所有链表节点值收集到列表中时间复杂度为 O(N) ;排序使用 python 的 sorted ,这里插一句 ,公号前期文章有 8 大排序算法的介绍 ,这步复杂度为 O(NlogN) ;第三步则是再创建链表 ,转换为目标结构为 O(N)
  2. 空间复杂度 ,排序过程的空间复杂度取决于使用的算法 ,创建列表过程为 O(N)

3.jpg


相关文章
|
3月前
【力扣】-- 移除链表元素
【力扣】-- 移除链表元素
41 1
|
3月前
Leetcode第21题(合并两个有序链表)
这篇文章介绍了如何使用非递归和递归方法解决LeetCode第21题,即合并两个有序链表的问题。
56 0
Leetcode第21题(合并两个有序链表)
|
3月前
|
存储 算法
【❤️算法笔记❤️】-每日一刷-21、合并两个有序链表
【❤️算法笔记❤️】-每日一刷-21、合并两个有序链表
117 0
|
3月前
LeetCode第二十四题(两两交换链表中的节点)
这篇文章介绍了LeetCode第24题的解法,即如何通过使用三个指针(preNode, curNode, curNextNode)来两两交换链表中的节点,并提供了详细的代码实现。
30 0
LeetCode第二十四题(两两交换链表中的节点)
|
3月前
Leetcode第十九题(删除链表的倒数第N个节点)
LeetCode第19题要求删除链表的倒数第N个节点,可以通过快慢指针法在一次遍历中实现。
48 0
Leetcode第十九题(删除链表的倒数第N个节点)
|
3月前
|
索引
力扣(LeetCode)数据结构练习题(3)------链表
力扣(LeetCode)数据结构练习题(3)------链表
106 0
|
3月前
【LeetCode 10】142. 环形链表 II
【LeetCode 10】142. 环形链表 II
24 0
|
3月前
【LeetCode 09】19 删除链表的倒数第 N 个结点
【LeetCode 09】19 删除链表的倒数第 N 个结点
19 0
|
3月前
【LeetCode 08】206 反转链表
【LeetCode 08】206 反转链表
14 0
|
3月前
【LeetCode 06】203.移除链表元素
【LeetCode 06】203.移除链表元素
35 0