-
Notifications
You must be signed in to change notification settings - Fork 18
/
Copy pathQuickSort.java
80 lines (68 loc) · 2 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
import java.util.Scanner;
public class QuickSort
{
/* This function takes last element as pivot,
places the pivot element at its correct
position in sorted array, and places all
smaller (smaller than pivot) to left of
pivot and all greater elements to right
of pivot */
private int partition(int arr[], int low, int high)
{
int pivot = arr[high];
int i = (low-1); // index of smaller element
for (int j=low; j<high; j++)
{
// If current element is smaller than or
// equal to pivot
if (arr[j] <= pivot)
{
i++;
// swap arr[i] and arr[j]
int temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
}
// swap arr[i+1] and arr[high] (or pivot)
int temp = arr[i+1];
arr[i+1] = arr[high];
arr[high] = temp;
return i+1;
}
/**
*
* @param arr
* @param low
* @param high
*/
void quickSort(int arr[], int low, int high)
{
if (low < high)
{
/* pi is partitioning index, arr[pi] is
now at right place */
int pi = partition(arr, low, high);
// Recursively sort elements before
// partition and after partition
quickSort(arr, low, pi-1);
quickSort(arr, pi+1, high);
}
}
public static void main(String args[])
{
Scanner sc= new Scanner(System.in);
System.out.println("Enter number of elements to be sorted: ");
int num=sc.nextInt();
int array[] = new int[num];
System.out.println("Enter array elements");
for(int i=0; i< num; i++){
array[i] = sc.nextInt();
}
QuickSort ob = new QuickSort();
ob.quickSort(array, 0, num-1);
for(int i=0;i<num;i++){
System.out.print(array[i] + " ");
}
}
}