-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathQuickSort.java
51 lines (43 loc) · 1.06 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
/*
* Quick Sort
*/
public class QuickSort {
public static void quickSort(int arr[], int si , int ei) {
if(si>=ei){
return;
}
// last element
int pIdx = partition(arr,si,ei);
quickSort(arr, si, pIdx-1); // left
quickSort(arr, pIdx+1, ei); // right
}
public static int partition(int arr[], int si , int ei){
int pivot = arr[ei];
int i= si-1; // to make place for els smaller than pivot
for(int j=si; j<ei; j++){
if(arr[j]<=pivot){
i++;
//swap
int temp=arr[j];
arr[j]=arr[i];
arr[i]=temp;
}
}
i++;
int temp=pivot;
arr[ei]=arr[i];
arr[i]= temp;
return i;
}
public static void main(String[] args) {
int arr[]={6,3,9,8,2,5};
quickSort(arr,0,arr.length-1);
for(int i=0; i<arr.length; i++){
System.out.print(arr[i] + " ");
}
}
}
/*
* Output:
* 2 3 5 6 8 9
*/