[LeetCode]合并K个排序链表(Merge k Sorted Lists)
题目描述
合并 k 个排序链表,返回合并后的排序链表。请分析和描述算法的复杂度。
示例:
输入:
[
1->4->5,
1->3->4,
2->6
]
输出: 1->1->2->3->4->4->5->6
ListNode数据结构
class ListNode {
int val;
ListNode next;
ListNode(int x) {
val = x;
}
}解决方法
相邻链表两两合并,两两合并详情见合并两个有序链表![[LeetCode]合并K个排序链表(Merge k Sorted Lists) [LeetCode]合并K个排序链表(Merge k Sorted Lists)](https://cdn.ancii.com/article/image/v1/Qj/zb/RO/ORzjbQVFJasX5aR2DaTg2_Zx5KSH75KdTtVIpx5BAiZkLetKXSLPahWnUL3kJcgmjQtcttG1fBpA6F5a1RQlmd-O83zkF6xWmerxGt1H5a8.jpg)
public ListNode mergeKLists(ListNode[] lists) {
int interval = 1;
while (interval < lists.length) {
for (int i = 0; i < lists.length - interval; i += interval * 2) {
lists[i] = merge2Lists(lists[i], lists[i + interval]);
}
interval *= 2;
}
return lists.length > 0 ? lists[0] : null;
}
public ListNode merge2Lists(ListNode l1, ListNode l2) {
if (l1 == null)
return l2;
if (l2 == null)
return l1;
if (l1.val < l2.val) {
l1.next = merge2Lists(l1.next, l2);
return l1;
} else {
l2.next = merge2Lists(l1, l2.next);
return l2;
}
}时间复杂度: O(Nlogk),k是链表的数目
相关推荐
earthhouge 2020-08-15
dbhllnr 2020-06-04
koushr 2020-11-12
范范 2020-10-28
zhaochen00 2020-10-13
Mars的自语 2020-09-27
steeven 2020-09-18
kka 2020-09-14
qiangde 2020-09-13
聚沙成塔积水成渊 2020-08-16
aanndd 2020-08-12
范范 2020-07-30
bluetears 2020-07-28
mingyunxiaohai 2020-07-19
horizonheart 2020-07-19
liushall 2020-07-18
bluetears 2020-07-05
fengshantao 2020-07-02
liuweixiao0 2020-06-27