-
Notifications
You must be signed in to change notification settings - Fork 5
Expand file tree
/
Copy pathmergeSort.ts
More file actions
31 lines (30 loc) · 780 Bytes
/
mergeSort.ts
File metadata and controls
31 lines (30 loc) · 780 Bytes
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
function merge(left: number[], right: number[]): number[] {
let sortArr: number[] = []
while (left.length > 0 && right.length > 0) {
if (left[0] < right[0]) {
sortArr.push(left.shift())
} else {
sortArr.push(right.shift())
}
}
if (left.length > 0) {
sortArr = sortArr.concat(...left)
}
if (right.length > 0) {
sortArr = sortArr.concat(...right)
}
return sortArr
}
export function mergeSort(arr: number[]) {
const {length} = arr
let half = Math.floor(length / 2)
let left = arr.slice(0, half)
let right = arr.slice(half)
if (left.length > 1) {
mergeSort(left)
}
if (right.length > 1) {
mergeSort(right)
}
return merge(left, right)
}