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:
Immutable Objects in Java
Java Program to Create a Minimal Set of All Edges Whose Addition will Convert it to a Strongly Conne...
Concatenating Strings In Java
Java Program to Create a Random Linear Extension for a DAG
Spring Cloud – Adding Angular
Biểu thức Lambda trong Java 8 – Lambda Expressions
Introduction to Spring MVC HandlerInterceptor
Pagination and Sorting using Spring Data JPA
Java – Convert File to InputStream
Guide to Java 8 groupingBy Collector
Java Program to Find Inverse of a Matrix
Java Program to Find the Shortest Path Between Two Vertices Using Dijkstra’s Algorithm
Java Program to Implement CountMinSketch
Java Program to Implement Range Tree
Java Program to Implement Skew Heap
Introduction to Liquibase Rollback
A Custom Media Type for a Spring REST API
Guide to java.util.concurrent.Future
Java Program to Construct an Expression Tree for an Infix Expression
The Difference Between Collection.stream().forEach() and Collection.forEach()
Mệnh đề if-else trong java
Java Program to Describe the Representation of Graph using Incidence List
Java Program to Find Whether a Path Exists Between 2 Given Nodes
Guide to BufferedReader
Java Program to Implement IdentityHashMap API
Java Program to Solve Tower of Hanoi Problem using Stacks
Spring Boot - Twilio
Hướng dẫn Java Design Pattern – Composite
Java – Write to File
Static Content in Spring WebFlux
Convert char to String in Java
OAuth2 for a Spring REST API – Handle the Refresh Token in AngularJS