34.合并 K 个升序链表(学习)
给你一个链表数组,每个链表都已经按升序排列。
请你将所有链表合并到一个升序链表中,返回合并后的链表。
示例 1:
输入:lists = [[1,4,5],[1,3,4],[2,6]]
输出:[1,1,2,3,4,4,5,6]
解释:链表数组如下:
[
1->4->5,
1->3->4,
2->6
]
将它们合并到一个有序链表中得到。
1->1->2->3->4->4->5->6
示例 2:
输入:lists = []
输出:[]
示例 3:
输入:lists = [[]]
输出:[]
提示:
k == lists.length
0 <= k <= 10^4
0 <= lists[i].length <= 500
-10^4 <= lists[i][j] <= 10^4
lists[i] 按 升序 排列
lists[i].length 的总和不超过 10^4
解析:
1.初始化:
创建一个空的结果链表(通常是一个带有哑节点的链表,以便于处理边界情况)。
创建一个空的最小堆(在这里我们用数组表示)。
遍历输入的链表数组,将每个链表的头节点(如果非空)加入最小堆。
2.合并过程:
当最小堆不为空时,执行以下操作:
从最小堆中移除并获取最小节点(即堆顶元素)。
将该节点添加到结果链表的末尾。
如果该节点不是其所在链表的最后一个节点,则将其下一个节点加入最小堆。
3.返回结果:
返回结果链表的头节点(跳过哑节点)。
var mergeKLists = function(lists) {
// 将所有链表的节点值收集到数组中
let values = [];
for (let list of lists) {
let current = list;
while (current) {
values.push(current.val);
current = current.next;
}
}
// 对数组进行排序
values.sort((a, b) => a - b);
// 根据排序后的数组创建链表
let dummy = new ListNode(0);
let current = dummy;
for (let val of values) {
current.next = new ListNode(val);
current = current.next;
}
return dummy.next;
};