amazon Min Cost to Connect Ropes / Min Time to Merge Files

link

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
class Solution{
private static int mergeFiles(int[] files) {
Queue<Integer> minHeap = new PriorityQueue<Integer>();
for(int f : files) {
minHeap.offer(f);
}
int res = 0;
while(minHeap.size() > 1) {
int f1 = minHeap.poll();
int f2 = minHeap.poll();
int tmp = f1 + f2;
res += tmp;
minHeap.offer(tmp);
}
return res;
}
}
/*
class MyClass{
public static void main(String[] args) {
int[] files1 = {8, 4, 6, 12};
int[] files2 = {20, 4, 8, 2};
int[] files3 = {1, 2, 5, 10, 35, 89};
int[] files4 = {2, 2, 3, 3};
System.out.println(mergeFiles(files1));
System.out.println(mergeFiles(files2));
System.out.println(mergeFiles(files3));
System.out.println(mergeFiles(files4));
}
}*/
0%