Preparation Code Preparation HTML (this will be inserted in the <body>
of a valid HTML5 document in standards mode) (useful when testing DOM operations or including libraries) <script src ="https://rawgithub.com/escherba/algorithms-in-javascript/master/src/common.js" >
</script >
<script src ="https://rawgithub.com/escherba/algorithms-in-javascript/master/src/bubble-sort.js" >
</script >
<script src ="https://rawgithub.com/escherba/algorithms-in-javascript/master/src/insertion-sort.js" >
</script >
<script src ="https://rawgithub.com/escherba/algorithms-in-javascript/master/src/merge-sort.js" >
</script >
<script >
aij.mergeSort2 = (function ( ){
"use strict" ;
function simpleMerge (a, from , pivot, to, buffer ) {
var i = -1 ;
while (++i < to - pivot) {
buffer[i] = a[i + pivot];
}
--i;
--pivot;
while (i >= 0 ) {
--to;
if (pivot >= from && buffer[i] < a[pivot]) {
a[to] = a[pivot];
--pivot;
} else {
a[to] = buffer[i];
--i;
}
}
}
function mergeSort (a, from , to, buffer ) {
if (to - from > 1 ) {
var middle = from + Math .floor ((to - from ) / 2 );
mergeSort (a, from , middle, buffer);
mergeSort (a, middle, to, buffer);
simpleMerge (a, from , middle, to, buffer);
}
return a;
}
return function (items ) { return mergeSort (items, 0 , items.length , items.slice (0 , Math .floor ((items.length + 1 ) / 2 ))); };
})();
var stableQuickSort = function (array, from , to, buffer, buffer2 ) {
while (to - from > 1 ) {
var pivotIndex = from + Math .floor ((to - from ) / 2 );
var pivot = array[pivotIndex];
var i = from - 1 ;
var k = from - 1 ;
var l = -1 ;
var m = -1 ;
while (++i < to) {
var c = array[i] < pivot ? -1 : (pivot < array[i] ? 1 : 0 );
if (c < 0 ) {
array[++k] = array[i];
} else if (c > 0 ) {
buffer[++l] = array[i];
} else {
buffer2[++m] = array[i];
}
}
++k;
++m;
++l;
i = -1 ;
while (++i < m) {
array[k + i] = buffer2[i];
}
i = -1 ;
while (++i < l) {
array[k + m + i] = buffer[i];
}
if (k - from < to - (k + m)) {
stableQuickSort (array, from , k, buffer, buffer2);
from = k + m;
} else {
stableQuickSort (array, k + m, to, buffer, buffer2);
to = k;
}
}
return array;
};
</script >
<script src ="https://rawgithub.com/escherba/algorithms-in-javascript/master/src/adaptive-sort.js" >
</script >
<script src ="https://rawgithub.com/escherba/algorithms-in-javascript/master/src/quickmiddle-sort.js" >
</script >
<script src ="https://rawgithub.com/escherba/algorithms-in-javascript/master/src/selection-sort.js" >
</script >
<script src ="https://rawgithub.com/escherba/algorithms-in-javascript/master/src/flashsort.js" >
</script >
<script src ="https://rawgithub.com/escherba/algorithms-in-javascript/master/src/heap-sort.js" >
</script >
Setup JS
testArrayLength = 10000 ;
var unsortedTestArray = new Array (testArrayLength);
for (var i = 0 ; i < testArrayLength; i++) {
unsortedTestArray[i] = Math .floor (Math .random ()*100000 );
}
var sortedTestArray = unsortedTestArray.clone ().sort (function compareNumbers (a, b ) {
return a - b;
});
Teardown JS
if (!result.compare (sortedTestArray)) {
throw new Error ("Array was not sorted" );
}
Test cases
Test #1 Title *
Async
Code * var result = unsortedTestArray.clone ().sort (function compareNumbers (a, b ) {
return a - b;
});
Test #2 Title *
Async
Code * var result = aij.insertionSort (unsortedTestArray.clone ());
Title *
Async
Code * var result = aij.heapSort (unsortedTestArray.clone ());
Title *
Async
Code * var result = aij.adaptiveSort (unsortedTestArray.clone ());
Title *
Async
Code * var result = aij.mergeSort (unsortedTestArray.clone ());
Title *
Async
Code * var result = aij.quickmiddleSort (unsortedTestArray.clone ());
Title *
Async
Code * var result = aij.flashSort (unsortedTestArray.clone ());
Title *
Async
Code * var result = aij.mergeSort2 (unsortedTestArray.clone ());
Title *
Async
Code * var result = stableQuickSort (unsortedTestArray.clone (), 0 , unsortedTestArray.length , [], []);