Test case details

Preparation Code

<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>
// Generate array with 10,000 random integers.     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;     });
    if (!result.compare(sortedTestArray)) {        throw new Error("Array was not sorted");     }

Test cases

Test #1

var result = unsortedTestArray.clone().sort(function compareNumbers(a, b) {   return a - b; });

Test #2

var result = aij.insertionSort(unsortedTestArray.clone());

Test #3

var result = aij.heapSort(unsortedTestArray.clone());

Test #4

var result = aij.adaptiveSort(unsortedTestArray.clone());

Test #5

var result = aij.mergeSort(unsortedTestArray.clone());

Test #6

var result = aij.quickmiddleSort(unsortedTestArray.clone());

Test #7

var result = aij.flashSort(unsortedTestArray.clone());

Test #8

var result = aij.mergeSort2(unsortedTestArray.clone());

Test #9

var result = stableQuickSort(unsortedTestArray.clone(), 0, unsortedTestArray.length, [], []);