This is a java program to perform sorting using Randomized Quick Sort. Randomized Quick Sort randomly selects a pivot element, after selecting pivot standard procedure is to be followed as quick sort.
Here is the source code of the Java Program to Implement Quick Sort Using Randomization. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
//This is a java program to sort numbers using randomized quick sort
import java.util.Random;
public class Randomized_Quick_Sort
{
public static int N = 20;
public static int[] sequence = new int[N];
public static void QuickSort(int left, int right)
{
if (right - left <= 0)
return;
else
{
Random rand = new Random();
int pivotIndex = left + rand.nextInt(right - left + 1);
swap(pivotIndex, right);
int pivot = sequence[right];
int partition = partitionIt(left, right, pivot);
QuickSort(left, partition - 1);
QuickSort(partition + 1, right);
}
}
public static int partitionIt(int left, int right, long pivot)
{
int leftPtr = left - 1;
int rightPtr = right;
while (true)
{
while (sequence[++leftPtr] < pivot)
;
while (rightPtr > 0 && sequence[--rightPtr] > pivot)
;
if (leftPtr >= rightPtr)
break;
else
swap(leftPtr, rightPtr);
}
swap(leftPtr, right);
return leftPtr;
}
public static void swap(int dex1, int dex2)
{
int temp = sequence[dex1];
sequence[dex1] = sequence[dex2];
sequence[dex2] = temp;
}
static void printSequence(int[] sorted_sequence)
{
for (int i = 0; i < sorted_sequence.length; i++)
System.out.print(sorted_sequence[i] + " ");
}
public static void main(String args[])
{
System.out
.println("Sorting of randomly generated numbers using RANDOMIZED QUICK SORT");
Random random = new Random();
for (int i = 0; i < N; i++)
sequence[i] = Math.abs(random.nextInt(100));
System.out.println("\nOriginal Sequence: ");
printSequence(sequence);
System.out.println("\nSorted Sequence: ");
QuickSort(0, N - 1);
printSequence(sequence);
}
}
Output:
$ javac Randomized_Quick_Sort.java $ java Randomized_Quick_Sort Sorting of randomly generated numbers using RANDOMIZED QUICK SORT Original Sequence: 98 95 22 64 77 49 11 98 56 63 84 18 9 68 4 69 2 20 68 4 Sorted Sequence: 2 4 4 9 11 18 20 22 49 56 63 64 68 68 69 77 84 95 98 98
Related posts:
Java Program to Implement Bresenham Line Algorithm
Spring Boot - Exception Handling
Java equals() and hashCode() Contracts
Java Program to Find the GCD and LCM of two Numbers
Java Program to Compare Binary and Sequential Search
Deploy a Spring Boot WAR into a Tomcat Server
Java Program to Convert a Decimal Number to Binary Number using Stacks
Using Spring @ResponseStatus to Set HTTP Status Code
Java Program to Perform Naive String Matching
Java Program to Implement Find all Cross Edges in a Graph
Tính kế thừa (Inheritance) trong java
Spring REST API with Protocol Buffers
Java Program to Implement Best-First Search
Java Program to Implement Attribute API
Java Program to Check the Connectivity of Graph Using DFS
Java Program to Implement Singly Linked List
Spring Boot Application as a Service
Sort a HashMap in Java
Java Program to Create a Balanced Binary Tree of the Incoming Data
Java Program to Implement Hamiltonian Cycle Algorithm
JUnit 5 for Kotlin Developers
New Features in Java 12
A Guide to Queries in Spring Data MongoDB
Tính trừu tượng (Abstraction) trong Java
Reactive Flow with MongoDB, Kotlin, and Spring WebFlux
Call Methods at Runtime Using Java Reflection
Send email with SMTPS (eg. Google GMail)
Từ khóa static và final trong java
Java Program to Compute the Volume of a Tetrahedron Using Determinants
How to Get a Name of a Method Being Executed?
Comparing Dates in Java
Spring WebClient Filters