
You are given an array of k linked-lists lists, each linked-list is sorted in ascending order.
Merge all the linked-lists into one sorted linked-list and return it.
1
2
3
4
5
6
7
8
9
10
11
12
| Example 1:
Input: lists = [[1,4,5],[1,3,4],[2,6]]
Output: [1,1,2,3,4,4,5,6]
Explanation: The linked-lists are:
[
1->4->5,
1->3->4,
2->6
]
merging them into one sorted list:
1->1->2->3->4->4->5->6
|
1
2
3
4
| Example 2:
Input: lists = []
Output: []
|
1
2
3
4
| Example 3:
Input: lists = [[]]
Output: []
|
Constraints:
- k == lists.length
- 0 <= k <= 10^4
- 0 <= lists[i].length <= 500
- -10^4 <= lists[i][j] <= 10^4
- lists[i] is sorted in ascending order.
- The sum of lists[i].length won’t exceed 10^4.
Solution#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
| /**
* Definition for singly-linked list.
* public class ListNode {
* int val;
* ListNode next;
* ListNode() {}
* ListNode(int val) { this.val = val; }
* ListNode(int val, ListNode next) { this.val = val; this.next = next; }
* }
*/
class Solution {
public ListNode mergeKLists(ListNode[] lists) {
PriorityQueue<ListNode> heap = new PriorityQueue<>((a,b) -> {
return a.val - b.val;
});
ListNode head = new ListNode();
ListNode curr = head;
for (ListNode node: lists) {
if (node != null) {
heap.add(node);
}
}
while (heap.size() > 0) {
ListNode node = heap.poll();
curr.next = new ListNode(node.val);
curr = curr.next;
if (node.next != null) {
heap.add(node.next);
}
}
return head.next;
}
}
|