01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
package algs21;
import stdlib.*;
import algs22.*;
import algs23.*;
import algs24.*;
/* ***********************************************************************
 *  Compilation:  javac SortCompare.java
 *  Execution:    java SortCompare alg1 alg2 N T
 *
 *  Sort N random real numbers, T times using the two
 *  algorithms specified on the command line.
 *
 *  % java SortCompare Insertion Selection 1000 100
 *  For 1000 random Doubles
 *    Insertion is 1.7 times faster than Selection
 *
 *************************************************************************/

public class XSortCompare {

  public static double time(String alg, Double[] a) {
    Stopwatch sw = new Stopwatch();
    if (alg.equals("Insertion"))  Insertion.sort(a);
    if (alg.equals("InsertionX")) XInsertionX.sort(a);
    if (alg.equals("Selection"))  Selection.sort(a);
    if (alg.equals("Shell"))      Shell.sort(a);
    if (alg.equals("Merge"))      Merge.sort(a);
    if (alg.equals("MergeX"))     XMergeX.sort(a);
    if (alg.equals("MergeBU"))    MergeBU.sort(a);
    if (alg.equals("Quick"))      Quick.sort(a);
    if (alg.equals("Quick3way"))  Quick3way.sort(a);
    if (alg.equals("QuickX"))     XQuickX.sort(a);
    if (alg.equals("Heap"))       Heap.sort(a);
    return sw.elapsedTime();
  }

  // Use alg to sort T random arrays of length N.
  public static double timeRandomInput(String alg, int N, int T)  {
    double total = 0.0;
    Double[] a = new Double[N];
    // Perform one experiment (generate and sort an array).
    for (int t = 0; t < T; t++) {
      for (int i = 0; i < N; i++)
        a[i] = StdRandom.uniform();
      total += time(alg, a);
    }
    return total;
  }

  public static void main(String[] args) {
    args = new String[] { "InsertionX", "Insertion", "10000", "20" };
    String alg1 = args[0];
    String alg2 = args[1];
    int N = Integer.parseInt(args[2]);
    int T = Integer.parseInt(args[3]);
    double time1 = timeRandomInput(alg1, N, T); // Total for alg1.
    double time2 = timeRandomInput(alg2, N, T); // Total for alg2.
    StdOut.format("For %d random Doubles\n    %s is", N, alg1);
    StdOut.format(" %.2f times faster than %s\n", time2/time1, alg2);
  }
}