forked from kelvins/algorithms-and-data-structures
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathCombSort.js
More file actions
23 lines (18 loc) · 667 Bytes
/
CombSort.js
File metadata and controls
23 lines (18 loc) · 667 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
function combSort(unsortedArray, start, end) {
let gap = end;
let swapped;
do {
swapped = false;
gap = parseInt(gap / 1.24733095);
for (let i = start; i < end - gap; i++) {
if (unsortedArray[i] > unsortedArray[i + gap]) {
[unsortedArray[i], unsortedArray[i + gap]] = [unsortedArray[i + gap], unsortedArray[i]];
swapped = true;
}
}
} while (gap > 1 || swapped);
return unsortedArray;
}
var unsortedArray = [54, 42, 11, 33, 24, 99, 77, 80];
let sortedArrayViaCombSort = combSort(unsortedArray, 0, unsortedArray.length);
console.log(sortedArrayViaCombSort);