Name Best-case Average-case Worst-case Memory Stable
BucketSort - n + r n + r n + r yes

BucketSort


Your browser does not support the HTML5 canvas tag.

Java Code

// for arrays with integers from 0 to 99
public void bucketSort(int[] array) {
     int counter = 0;
     LinkedList<LinkedList<Integer>> allBuckets = new LinkedList<LinkedList<Integer>>();

     for(int i = 0; i < 10; i++) {
          allBuckets.addLast(new LinkedList<Integer>());
     }

     for (int i = 0; i < array.length; i++) {
          int j = array[ i ] % 10;
          allBuckets.get( j ).addLast( array[ i ] );
     }

     for(int i = 0; i < 10; i++){
          for(int j = 0; j < allBuckets.get( i ).size(); j++) {
               array[counter] = allBuckets.get( i ).get( j );
               counter++;
          }
     }

     insertionSort(array);

}

public void insertionSort(int[] array) {
     int i;
     int key;

     for (int j = 1; j < array.length; j++) {
          key = array[ j ];
          i = j - 1;

          while (( i >= 0 ) && ( array[ i ] > key) ) {
               array[ i + 1 ] = array[ i ];
               i--;
          }

          array[ i + 1 ] = key;
     }
}
            

How to use

Use the textfield to type in a number and add it by either pressing ENTER or by clicking on the "Add" button.
You can also add 10 random numbers at once by clicking on the "10 Random Keys" button. Overall you can add up to 20 keys.
The "Sort" button starts to sort the keys with the selected algorithm.