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:
Introduction to Spring MVC HandlerInterceptor
Spring Boot - Scheduling
Quick Guide to Spring Bean Scopes
Logging in Spring Boot
Java Program to Find Median of Elements where Elements are Stored in 2 Different Arrays
Java Program to Generate All Possible Combinations Out of a, b, c, d, e
Java Program to Perform String Matching Using String Library
Java – Delete a File
An Introduction to Java.util.Hashtable Class
Java Program to Find a Good Feedback Vertex Set
Java Program to Perform Partition of an Integer in All Possible Ways
ETL with Spring Cloud Data Flow
Java Program to Check if a Given Set of Three Points Lie on a Single Line or Not
Java Program to Check whether Graph is Biconnected
Integer Constant Pool trong Java
Java Program to Implement DelayQueue API
Guide to Guava Table
Java Program to Implement Min Heap
Spring Security Login Page with React
Kết hợp Java Reflection và Java Annotations
Java Program to Perform Arithmetic Operations on Numbers of Size
Java Scanner hasNext() vs. hasNextLine()
Check if there is mail waiting
Rest Web service: Filter và Interceptor với Jersey 2.x (P2)
Java Program to Check whether Graph is a Bipartite using 2 Color Algorithm
Java Program to Find the Median of two Sorted Arrays using Binary Search Approach
Java Program to Check Whether a Directed Graph Contains a Eulerian Cycle
Spring – Injecting Collections
Java Program to Implement Red Black Tree
Java Program to Check whether Graph is a Bipartite using DFS
Java Deep Learning Essentials - Yusuke Sugomori
Guide to PriorityBlockingQueue in Java