This is a java program to find the ith largest element from a list using order-statistic algorithm. This version of the code uses quick sort partitioning technique.
Here is the source code of the Java Program to Find ith Largest Number from a Given List Using Order-Statistic Algorithm. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
package com.sanfoundry.combinatorial;
import java.util.Scanner;
public class KthLargestOrderStatistics
{
public static int partition(int[] array, int first, int last)
{
int pivot = array[first];
int pivotPosition = first++;
while (first <= last)
{
// scan for values less than the pivot
while ((first <= last) && (array[first] < pivot))
{
first++;
}
// scan for values greater than the pivot
while ((last >= first) && (array[last] >= pivot))
{
last--;
}
if (first > last)
{
// swap the last uncoformed
// element with the pivot
swap(array, pivotPosition, last);
}
else
{
// swap unconformed elements:
// first that was not lesser than the pivot
// and last that was not larger than the pivot
swap(array, first, last);
}
}
return last;
}
private static void swap(int[] array, int first, int last)
{
int temp;
temp = array[first];
array[first] = array[last];
array[last] = temp;
}
public static int orderStatistic(int[] array, int k, int first, int last)
{
int pivotPosition = partition(array, first, last);
if (pivotPosition == k - 1)
{
return array[k - 1];
}
if (k - 1 < pivotPosition)
{
return orderStatistics(array, k, first, pivotPosition - 1);
}
else
{
return orderStatistics(array, k, pivotPosition + 1, last);
}
}
// iterative version
private static int orderStatistics(int[] array, int k, int first, int last)
{
int pivotPosition = partition(array, first, last);
while (pivotPosition != k - 1)
{
if (k - 1 < pivotPosition)
{
last = pivotPosition - 1;
}
else
{
first = pivotPosition + 1;
}
pivotPosition = partition(array, first, last);
}
return array[k - 1];
}
public static int kthSmallest(int[] array, int k)
{
return orderStatistic(array, k, 0, array.length - 1);
}
public static int kthLargest(int[] array, int k)
{
return orderStatistic(array, array.length - k + 1, 0, array.length - 1);
}
public static void main(String[] args)
{
Scanner sc = new Scanner(System.in);
System.out.println("Enter the number of elements in the sequence: ");
int n = sc.nextInt();
int[] sequence = new int[n];
System.out.println("Enter the elements of the sequence: ");
for (int i = 0; i < sequence.length; i++)
{
sequence[i] = sc.nextInt();
}
System.out
.println("Enter the kth index to be returned as kth largest element of the sequence:");
int k = sc.nextInt();
System.out.println("Kth largest:" + kthLargest(sequence, k));
sc.close();
}
}
Output:
$ javac KthLargestOrderStatistics.java $ java KthLargestOrderStatistics Enter the number of elements in the sequence: 10 Enter the elements of the sequence: 2 5 6 7 4 7 9 5 8 1 Enter the kth index to be returned as kth largest element of the sequence: 4 Kth largest:7
Related posts:
Java Program to Implement Hash Tables with Linear Probing
@Before vs @BeforeClass vs @BeforeEach vs @BeforeAll
Hướng dẫn Java Design Pattern – DAO
Default Password Encoder in Spring Security 5
Overflow and Underflow in Java
Java Program to Perform the Unique Factorization of a Given Number
A Guide to JUnit 5 Extensions
Java Program to Solve Knapsack Problem Using Dynamic Programming
Kiểu dữ liệu Ngày Giờ (Date Time) trong java
Retrieve User Information in Spring Security
Working with Tree Model Nodes in Jackson
Java 8 StringJoiner
SOAP Web service: Authentication trong JAX-WS
Spring Boot - Logging
Supplier trong Java 8
Intro to Inversion of Control and Dependency Injection with Spring
Java Program to Check if any Graph is Possible to be Constructed for a Given Degree Sequence
Sorting in Java
Guide to Selenium with JUnit / TestNG
Ép kiểu trong Java (Type casting)
Using a Custom Spring MVC’s Handler Interceptor to Manage Sessions
Java Program to Implement Depth-limited Search
Spring Boot - Google Cloud Platform
Java Program to Perform Deletion in a BST
Java Program to Delete a Particular Node in a Tree Without Using Recursion
Primitive Type Streams in Java 8
Java Program to Implement Graph Coloring Algorithm
Getting Started with Forms in Spring MVC
Java Program to Generate Random Numbers Using Multiply with Carry Method
Apache Commons Collections SetUtils
Java Program to Perform Right Rotation on a Binary Search Tree
Java Program to subtract two large numbers using Linked Lists