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:
Daemon Threads in Java
Java Program to Implement Hopcroft Algorithm
Java Program to Check if a Directed Graph is a Tree or Not Using DFS
Guide to Character Encoding
Custom Cascading in Spring Data MongoDB
Collect a Java Stream to an Immutable Collection
Java Program to Implement Aho-Corasick Algorithm for String Matching
Java Program to Perform String Matching Using String Library
Java Program to Implement Ternary Tree
Call Methods at Runtime Using Java Reflection
Spring WebClient Requests with Parameters
Java Program to Print only Odd Numbered Levels of a Tree
Java – String to Reader
Add Multiple Items to an Java ArrayList
Ignore Null Fields with Jackson
Convert a Map to an Array, List or Set in Java
Spring Boot - Tomcat Deployment
Use Liquibase to Safely Evolve Your Database Schema
Java Program to Implement Sorting of Less than 100 Numbers in O(n) Complexity
Java Program to Implement Nth Root Algorithm
Hướng dẫn Java Design Pattern – Dependency Injection
Java Program to Implement Kosaraju Algorithm
Spring Cloud AWS – S3
Array to String Conversions
Check If Two Lists are Equal in Java
Java Program to Compute Discrete Fourier Transform Using Naive Approach
Removing all Nulls from a List in Java
Testing an OAuth Secured API with Spring MVC
Java toString() Method
Show Hibernate/JPA SQL Statements from Spring Boot
So sánh ArrayList và Vector trong Java
Guide to the Volatile Keyword in Java