-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathShellSort.java
More file actions
47 lines (28 loc) · 1.1 KB
/
ShellSort.java
File metadata and controls
47 lines (28 loc) · 1.1 KB
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
import java.util.Arrays;
public class ShellSort {
String complexity;
ShellSort() {
complexity = ". Quadratic (Unstable) Time Complexity .";
}
void sort(int[] sortArray) {
/*
Begin Time Start
*/
double start = (double) System.nanoTime();
for (int count = sortArray.length / 2; count > 0; count /= 2) {
for (int countTwo = count; countTwo < sortArray.length; countTwo++) {
int tempInt = sortArray[countTwo];
int countThree;
for (countThree = countTwo; countThree >= count && sortArray[countThree - count] > tempInt; countThree -= count) {
sortArray[countThree] = sortArray[countThree - count];
}
sortArray[countThree] = tempInt;
}
}
/*
End Time
*/
double end = (double) System.nanoTime();
System.out.println("ShellSort: " + Arrays.toString(sortArray) + complexity + " Seconds taken was " + ((end - start) / 1000000));
}
}