-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathQuickSort.java
84 lines (71 loc) · 2.39 KB
/
QuickSort.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
import java.util.ArrayList;
// Implementation for Sorting Results using Quick Sort algorithm
public class QuickSort extends Sort {
// Constructor
// _result : result list to be sorted
public QuickSort( ArrayList<Data[]> result, DataStore dataStore ) {
super( result, dataStore );
}
// Method to sort an result list
// keys : columns to sort
public ArrayList<Data[]> Sort( String[] keys )
throws IllegalArgumentException
{
dataStore.checkKeyArgs( keys );
// Sort for each key
for ( String key : keys ) {
Data[] temp; // holds the interchanged element row
// Use first row (header) in result to get order of keys in result
int ncol = -1;
for ( int i = 0; i < result.get( 0 ).length; i++ ) {
if ( ((String)result.get( 0 )[ i ].Get()).compareTo( key ) == 0 ) {
ncol = i;
break;
}
}
// Check if key is in the result
if ( -1 == ncol )
throw new IllegalArgumentException( "Sort key not in result: " + key );
// Sort the outermost partition ( note, skip index 0 because this is the heading)
QuickSort( ncol, 1, result.size() - 1 );
}
return result;
}
protected void QuickSort( int ncol, int lowerIndex, int higherIndex ) {
int i = lowerIndex;
int j = higherIndex;
// find the pivot number ( middle index )
Data pivot = result.get( lowerIndex + (higherIndex-lowerIndex) / 2 )[ ncol ];
// Divide into two partitions
while ( i <= j ) {
/**
* In each iteration, we will identify a number from left side which
* is greater than the pivot value, and also we will identify a number
* from right side which is less than the pivot value. Once the search
* is done, then we exchange both numbers.
*/
while ( result.get( i )[ ncol ].LT( pivot ) ) {
i++;
}
while ( result.get( j )[ ncol ].GT( pivot ) ) {
j--;
}
if ( i <= j ) {
ExchangeNumbers( i, j );
//move index to next position on both sides
i++;
j--;
}
}
// call quickSort() method recursively
if ( lowerIndex < j )
QuickSort( ncol, lowerIndex, j );
if ( i < higherIndex )
QuickSort( ncol, i, higherIndex );
}
private void ExchangeNumbers( int i, int j ) {
Data[] temp = result.get( i );
result.set( i, result.get( j ) );
result.set( j, temp );
}
}