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:
ETL with Spring Cloud Data Flow
A Guide to Concurrent Queues in Java
Java Program to Implement Floyd-Warshall Algorithm
Guide to CountDownLatch in Java
Java 14 Record Keyword
Java Program to Generate Random Hexadecimal Byte
Spring Boot - Exception Handling
Spring Security with Maven
Hướng dẫn Java Design Pattern – Interpreter
Câu lệnh điều khiển vòng lặp trong Java (break, continue)
Abstract class và Interface trong Java
Spring 5 Testing with @EnabledIf Annotation
Mệnh đề if-else trong java
Spring RestTemplate Error Handling
Java Program to Find Inverse of a Matrix
Immutable Objects in Java
Lớp Arrarys trong Java (Arrays Utility Class)
Java Program to Implement D-ary-Heap
Java Program to Perform integer Partition for a Specific Case
Hướng dẫn Java Design Pattern – Singleton
Using the Not Operator in If Conditions in Java
Spring Boot - Cloud Configuration Client
Composition, Aggregation, and Association in Java
Xử lý ngoại lệ đối với trường hợp ghi đè phương thức trong java
Java Program to Find the Shortest Path Between Two Vertices Using Dijkstra’s Algorithm
Spring Boot - Introduction
Java Program to Perform the Sorting Using Counting Sort
Hướng dẫn Java Design Pattern – Composite
Bootstrap a Web Application with Spring 5
A Guide to JUnit 5
A Guide to Iterator in Java
Hướng dẫn sử dụng Java Reflection