This is a Java Program to Implement Jarvis Algorithm. Jarvis algorithm or the gift wrapping algorithm is an algorithm for computing the convex hull of a given set of points.
Here is the source code of the Java Program to Implement Jarvis Algorithm. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
/**
** Java Program to Implement Jarvis Algorithm
**/
import java.util.Scanner;
import java.util.Arrays;
/** Class point **/
class Point
{
int x, y;
}
/** Class Jarvis **/
public class Jarvis
{
private boolean CCW(Point p, Point q, Point r)
{
int val = (q.y - p.y) * (r.x - q.x) - (q.x - p.x) * (r.y - q.y);
if (val >= 0)
return false;
return true;
}
public void convexHull(Point[] points)
{
int n = points.length;
/** if less than 3 points return **/
if (n < 3)
return;
int[] next = new int[n];
Arrays.fill(next, -1);
/** find the leftmost point **/
int leftMost = 0;
for (int i = 1; i < n; i++)
if (points[i].x < points[leftMost].x)
leftMost = i;
int p = leftMost, q;
/** iterate till p becomes leftMost **/
do
{
/** wrapping **/
q = (p + 1) % n;
for (int i = 0; i < n; i++)
if (CCW(points[p], points[i], points[q]))
q = i;
next[p] = q;
p = q;
} while (p != leftMost);
/** Display result **/
display(points, next);
}
public void display(Point[] points, int[] next)
{
System.out.println("\nConvex Hull points : ");
for (int i = 0; i < next.length; i++)
if (next[i] != -1)
System.out.println("("+ points[i].x +", "+ points[i].y +")");
}
/** Main function **/
public static void main (String[] args)
{
Scanner scan = new Scanner(System.in);
System.out.println("Jarvis Algorithm Test\n");
/** Make an object of Jarvis class **/
Jarvis j = new Jarvis();
System.out.println("Enter number of points n :");
int n = scan.nextInt();
Point[] points = new Point[n];
System.out.println("Enter "+ n +" x, y cordinates");
for (int i = 0; i < n; i++)
{
points[i] = new Point();
points[i].x = scan.nextInt();
points[i].y = scan.nextInt();
}
j.convexHull(points);
}
}
Jarvis Algorithm Test Enter number of points n : 8 Enter 8 x, y cordinates 0 3 4 2 3 5 5 3 3 0 1 1 1 2 2 2 Convex Hull points : (0, 3) (3, 5) (5, 3) (3, 0) (1, 1)
Related posts:
Java Program to Find kth Smallest Element by the Method of Partitioning the Array
Spring Boot Change Context Path
Spring MVC Setup with Kotlin
How to Read a Large File Efficiently with Java
Hướng dẫn Java Design Pattern – Intercepting Filter
Java Program to Implement Caesar Cypher
Spring MVC Tutorial
Java Program to Implement Wagner and Fisher Algorithm for online String Matching
Most commonly used String methods in Java
Case-Insensitive String Matching in Java
Java Program to Implement AVL Tree
Java Timer
Java – InputStream to Reader
Use Liquibase to Safely Evolve Your Database Schema
Java Program to Find Number of Spanning Trees in a Complete Bipartite Graph
Java Program to Encode a Message Using Playfair Cipher
Java Program to Check whether Undirected Graph is Connected using DFS
Java Program to Implement Fermat Primality Test Algorithm
Object cloning trong java
Hướng dẫn Java Design Pattern – Composite
Java Program to Implement Skip List
Spring Boot - Runners
Java Program to Implement RoleList API
Convert XML to JSON Using Jackson
Spring Boot - Admin Server
Comparing Dates in Java
Setting the Java Version in Maven
Spring Boot - Actuator
Create Java Applet to Simulate Any Sorting Technique
Remove All Occurrences of a Specific Value from a List
Java Program to Implement Graph Structured Stack
A Guide to TreeSet in Java