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:
Logging a Reactive Sequence
JWT – Token-based Authentication trong Jersey 2.x
Guide to Guava Multimap
Java Program to Check whether Graph is a Bipartite using BFS
Hướng dẫn Java Design Pattern – Flyweight
Java Program to Perform Searching Using Self-Organizing Lists
Lớp HashMap trong Java
Spring MVC Setup with Kotlin
Java Program to Apply DFS to Perform the Topological Sorting of a Directed Acyclic Graph
Java Program to Check if a Given Graph Contain Hamiltonian Cycle or Not
Spring Boot - Securing Web Applications
Java Program to Implement Doubly Linked List
Calling Stored Procedures from Spring Data JPA Repositories
Service Registration with Eureka
Extract links from an HTML page
Java Program to Implement ArrayDeque API
A Guide to @RepeatedTest in Junit 5
Default Password Encoder in Spring Security 5
Java Program to Implement Counting Sort
Compare Two JSON Objects with Jackson
Java Program to Find the Longest Subsequence Common to All Sequences in a Set of Sequences
Introduction to Eclipse Collections
Introduction to Netflix Archaius with Spring Cloud
Java Program to Implement Solovay Strassen Primality Test Algorithm
Java Program to Create a Minimal Set of All Edges Whose Addition will Convert it to a Strongly Conne...
Guide to the Fork/Join Framework in Java
Prevent Cross-Site Scripting (XSS) in a Spring Application
Hướng dẫn Java Design Pattern – Transfer Object
Java Program to Check if a Directed Graph is a Tree or Not Using DFS
Java Program to Implement Dijkstra’s Algorithm using Queue
Java Program to Implement Attribute API
Java Program to Implement the Hungarian Algorithm for Bipartite Matching