-
Notifications
You must be signed in to change notification settings - Fork 101
/
merge-sort.ts
44 lines (36 loc) · 1.27 KB
/
merge-sort.ts
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
import head from 'lodash/head';
import { range } from '../../utils';
/**
* Divide and sort merges two subarrays of given array
* Time complexity: O(n)
* @param input The array which subarrays should be sorted
* @param start Start of the first array
* @param mid End of first array, not included
* @param end End of second array, not including
*/
export function merge(input: number[], start: number, mid: number, end: number) {
// Make a copy of the two subarrays
const left = input.slice(start, mid);
const right = input.slice(mid, end);
left[left.length] = Infinity as any;
right[right.length] = Infinity as any;
range(start, end - 1).forEach(index => {
if (head(left) <= head(right)) input[index] = left.shift();
else input[index] = right.shift();
});
return input;
}
/**
* Sort the input with merge sort.
* Time complexity: O(n * lg(n)).
* @param input The array which should be sorted
* @param start Left side of the subarray
* @param end Right side of the subarray, not included
*/
export function mergeSort(input: number[], start = 0, end = input.length): number[] {
if (end - start <= 1) return [];
const mid = Math.floor((start + end) / 2);
mergeSort(input, start, mid);
mergeSort(input, mid, end);
return merge(input, start, mid, end);
}