forked from jstephens9245/sorting
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbubblesort.js
50 lines (35 loc) · 981 Bytes
/
bubblesort.js
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
/* eslint-env node */
function bubbleSort (array) {
for (var i = 0; i < array.length; i++) {
for (var j = 0; j < array.length; j++) {
var nextVar = array[j + 1];
var curVar = array[j];
if(nextVar < curVar && nextVar !== undefined) {
array.splice(j, 2, nextVar, curVar);
}
}
}
return array;
}
function split (array) {
return [array.slice(0, Math.floor(array.length / 2)), array.slice(Math.floor(array.length / 2))];
}
function merge (array1, array2) {
var finalArray = [];
var sumArray = array1.length + array2.length;
for (var i = 0; i < sumArray; i++) {
if(array1[0] > array2[0] || !array1[0]) {
finalArray.push(array2.shift());
} else {
finalArray.push(array1.shift());
}
}
return finalArray;
}
function mergeSort (array) {
if(array.length === 1) {
return array;
}
var [firstArr, secondArr] = split(array);
return merge(mergeSort(firstArr), mergeSort(secondArr));
}