This is a Java Program to find the area of a polygon using slicker method. The algorithm assumes the usual mathematical convention that positive y points upwards. In computer systems where positive y is downwards (most of them) the easiest thing to do is list the vertices counter-clockwise using the “positive y down” coordinates. The two effects then cancel out to produce a positive area.
Here is the source code of the Java Program to Implement Slicker Algorithm that avoids Triangulation to Find Area of a Polygon. 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 find the area of polygon using Slicker algorithm
import java.util.*;
class Area_polygon_Slicker
{
static final int MAXPOLY = 200;
static final double EPSILON = 0.000001;
static class Point
{
double x, y;
}
static class Polygon
{
Point p[] = new Point[MAXPOLY];
int n;
Polygon()
{
for (int i = 0; i < MAXPOLY; i++)
p[i] = new Point();
}
}
static double area(Polygon p)
{
double total = 0;
for (int i = 0; i < p.n; i++)
{
int j = (i + 1) % p.n;
total += (p.p[i].x * p.p[j].y) - (p.p[j].x * p.p[i].y);
}
return total / 2;
}
static public void main(String[] args)
{
Polygon p = new Polygon();
Scanner sc = new Scanner(System.in);
System.out.println("Enter the number of points in Polygon: ");
p.n = sc.nextInt();
System.out.println("Enter the coordinates of each point: <x> <y>");
for (int i = 0; i < p.n; i++)
{
p.p[i].x = sc.nextDouble();
p.p[i].y = sc.nextDouble();
}
double area = area(p);
if (area > 0)
System.out.print("The Area of Polygon with " + p.n
+ " points using Slicker Algorithm is : " + area);
else
System.out.print("The Area of Polygon with " + p.n
+ " points using Slicker Algorithm is : " + (area * -1));
sc.close();
}
}
Output:
$ javac Area_polygon_Slicker.java $ java Area_polygon_Slicker Enter the number of points in Polygon: 4 Enter the coordinates of each point: <x> <y> 1 1 1 6 6 6 6 1 The Area of Polygon with 4 points using Slicker Algorithm is : 25.0 Enter the number of points in Polygon: 5 Enter the coordinates of each point: <x> <y> 1 2 4 5 9 8 3 2 1 5 The Area of Polygon with 5points using Slicker Algorithm is : 6.0
Related posts:
Java Program to Implement Borwein Algorithm
Spring Boot - Cloud Configuration Server
Java Program to Implement Self organizing List
Exploring the Spring Boot TestRestTemplate
Spring Boot - Rest Controller Unit Test
Guide to Character Encoding
Adding Shutdown Hooks for JVM Applications
Giới thiệu JDBC Connection Pool
Guide to DelayQueue
A Guide to @RepeatedTest in Junit 5
Jackson – JsonMappingException (No serializer found for class)
Java Program to Implement Adjacency List
Java Program to Sort an Array of 10 Elements Using Heap Sort Algorithm
A Guide to Java 9 Modularity
Java Program to Implement Sorted Circularly Singly Linked List
Hướng dẫn Java Design Pattern – Facade
Java Program to Compare Binary and Sequential Search
Introduction to the Functional Web Framework in Spring 5
Inheritance and Composition (Is-a vs Has-a relationship) in Java
Introduction to Thread Pools in Java
How to Use if/else Logic in Java 8 Streams
A Custom Media Type for a Spring REST API
How to Change the Default Port in Spring Boot
Java Program to Implement Double Order Traversal of a Binary Tree
Giới thiệu thư viện Apache Commons Chain
Using a Custom Spring MVC’s Handler Interceptor to Manage Sessions
Jackson – Unmarshall to Collection/Array
Java Program to Implement Levenshtein Distance Computing Algorithm
Java Program to Implement Sieve Of Sundaram
Java Program to Compute Cross Product of Two Vectors
Java Program to Implement ScapeGoat Tree
Java Program to implement Bit Set