-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathInsertionSortExample.java
87 lines (74 loc) · 1.81 KB
/
InsertionSortExample.java
1
2
3
4
5
6
7
8
9
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
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
import java.util.Random;
public class InsertionSortExample
{
/**
* O(n^2)
*
* Sorts the array in accenting order
*
* @param arr
* @return
*/
public static int[] insertionSort(int[] arr)
{
for (int j = 1; j < arr.length; j++)
{
int key = arr[j];
// insert arr[j] into sorted sequence
int i = j - 1;
while(i >= 0 && arr[i] > key)
{
arr[i+1] = arr[i];
i = i - 1;
}
arr[i+1] = key;
}
return arr;
}
public static void main(String[] args)
{
// int[] arr = {3, 1, 2, 4, 5, 6};
// ===== CONTROL ===== //
int amountOfIterations = 1000000;
int maxArrayLength = 10000;
// ================= //
long sumOfTime = 0;
for(int i = 0; i < amountOfIterations; i++)
{
Random rg = new Random();
int r = rg.nextInt(maxArrayLength);
int[] a = randomArrayGenerator(r + 1); // add 1 so it's never 0
long startTime = System.nanoTime();
a = insertionSort(a);
long endTime = System.nanoTime();
for(int k : a)
{
// System.out.print(k + " ");
}
sumOfTime += endTime - startTime;
// System.out.print("\n" + "It took " + (endTime - startTime) + " nanoseconds");
// System.out.print("\n");
}
long averageTime = sumOfTime/amountOfIterations;
System.out.println("AVERAGE TIME: " + averageTime);
}
// ============================ UTILITIES ======================== //
public static int[] randomArrayGenerator(int length)
{
int[] a = new int[length];
for (int i = 1; i <= length; i++)
{
a[i-1] = i;
}
Random rg = new Random();
int tmp;
for (int i = length-1; i > 0; i--)
{
int r = rg.nextInt(i+1);
tmp = a[r];
a[r] = a[i];
a[i] = tmp;
}
return a;
}
}