-
Notifications
You must be signed in to change notification settings - Fork 17
/
Copy pathMergeSortedArrays.java
66 lines (57 loc) · 2 KB
/
MergeSortedArrays.java
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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
package by.andd3dfx.common;
import lombok.AllArgsConstructor;
import java.util.Comparator;
import java.util.PriorityQueue;
/**
* <pre>
* Дано К массивов целых чисел длиной N каждый, упорядоченных по возрастанию.
* Вернуть один массив, содержащий все эти числа, также упорядоченные по возрастанию.
*
* Пример:
* [[1,2,3], [4,6,7], [2,5,9]] -> [1,2,2,3,4,5,6,7,9]
*
* Оценить сложность алгоритма; желательно получить его лучше, чем O(KN*log(KN)).
* </pre>
*
* @see <a href="https://youtu.be/HqGYyGYKtBs">Video solution</a>
*/
public class MergeSortedArrays {
/**
* Судя по всему сложность получается KN*log(K)
*/
public static int[] merge(int[][] arrays) {
final int K = arrays.length;
if (K == 0) {
return new int[]{};
}
final int N = arrays[0].length;
if (N == 0) {
return new int[]{};
}
var queue = new PriorityQueue<Item>(Comparator.comparingInt(item -> item.value));
for (int i = 0; i < K; i++) {
var value = arrays[i][0];
queue.add(new Item(value, i));
}
int[] result = new int[K * N];
int[] markers = new int[K];
int globalIndex = 0;
while (globalIndex < K * N) {
Item item = queue.poll();
result[globalIndex] = item.value;
globalIndex++;
var i = item.index; // array index in `arrays`
markers[i]++;
if (markers[i] < N) {
var value = arrays[i][markers[i]];
queue.add(new Item(value, i));
}
}
return result;
}
@AllArgsConstructor
public static class Item {
private int value;
private int index;
}
}