Create quicksort.js

This commit is contained in:
Vladislav Khvostov
2017-09-26 07:24:36 +03:00
committed by Aditya Bhargava
parent 44f8151e11
commit d76298722f

View File

@@ -0,0 +1,18 @@
const quickSort = (array) => {
if (array.length < 2) {
return array;
}
if (array.length === 2) {
// if first elem more than second will swap them and return it like new array.
return array[0] < array[1] ? array : [array[1], array[0]];
}
const pivot = array[0]
const itemsAreLessPivotSubArray = array.filter(item => item < pivot);
const itemsAreMoreThenPivotSubArray = array.filter(item => item > pivot);
return [...quickSort(itemsAreLessPivotSubArray), pivot, ...quickSort(itemsAreMoreThenPivotSubArray)];
};
module.exports = quickSort;
console.log(quicksort([10, 5, 2, 3])); // [2, 3, 5, 10]