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:
Jackson – JsonMappingException (No serializer found for class)
An Introduction to ThreadLocal in Java
Exploring the Spring Boot TestRestTemplate
Java Streams vs Vavr Streams
Spring Boot Change Context Path
How to Remove the Last Character of a String?
Java Program to Implement Kosaraju Algorithm
A Quick Guide to Using Keycloak with Spring Boot
So sánh HashMap và Hashtable trong Java
Java List UnsupportedOperationException
Send email with JavaMail
Java Program to Create a Random Graph Using Random Edge Generation
Concurrent Test Execution in Spring 5
Java Program to Implement the Hill Cypher
Split a String in Java
Giới thiệu về Stream API trong Java 8
Extra Login Fields with Spring Security
Spring Boot - Google Cloud Platform
Template Engines for Spring
Send an email using the SMTP protocol
Java Program to Perform LU Decomposition of any Matrix
Java Program to Compute Cross Product of Two Vectors
Java Program to Implement Ternary Heap
Derived Query Methods in Spring Data JPA Repositories
Immutable Objects in Java
Java Multi-line String
Java Program to Implement Merge Sort Algorithm on Linked List
Java Program to Find MST (Minimum Spanning Tree) using Kruskal’s Algorithm
Java Program to Implement TreeMap API
Java InputStream to String
A Guide to BitSet in Java
Spring Boot - Tomcat Deployment