-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathQuickSort.java
More file actions
32 lines (29 loc) · 817 Bytes
/
Copy pathQuickSort.java
File metadata and controls
32 lines (29 loc) · 817 Bytes
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
/*
* Average performance : O(n log n)
* Worst-case performance O(n * n)
* Space complexity : O(log n)
*/
void quickSort(int arr[], int left, int right){
int index = partition(arr, left, right);
if(left < index - 1){ // Sort the left part
quickSort(arr, left, index - 1);
}
if(index < right){ // Sort the right part
quickSort(arr, index, right);
}
}
int partition(int arr[], int left, int right){
int pivot = arr[(left + right) / 2]; // Find out a pivot
while(left <= right){
// Find out the elements on left which should be moved to right
while(arr[left] < pivot) left++;
// Find out the element on right which should be moved to left
while(arr[right] < pivot) right--;
if(left <= right){
swap(arr, left, right); // swap these two elements
left++;
right--;
}
}
return left;
}