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:
Removing all Nulls from a List in Java
Transactions with Spring and JPA
Using JWT with Spring Security OAuth (legacy stack)
Registration – Activate a New Account by Email
Configure a RestTemplate with RestTemplateBuilder
Hướng dẫn Java Design Pattern – Transfer Object
Java Program to Perform Quick Sort on Large Number of Elements
Java Program to Implement Sorting of Less than 100 Numbers in O(n) Complexity
Spring Security Login Page with React
Spring Boot - Internationalization
Java Program to Find SSSP (Single Source Shortest Path) in DAG (Directed Acyclic Graphs)
Control Structures in Java
The Registration API becomes RESTful
Hướng dẫn Java Design Pattern – Intercepting Filter
Giới thiệu Google Guice – Injection, Scope
Quick Intro to Spring Cloud Configuration
TreeSet và sử dụng Comparable, Comparator trong java
Jackson – Bidirectional Relationships
Cài đặt và sử dụng Swagger UI
Optional trong Java 8
Java Program to Implement Aho-Corasick Algorithm for String Matching
Hướng dẫn Java Design Pattern – Prototype
Giới thiệu luồng vào ra (I/O) trong Java
Disable DNS caching
Java Program to Implement Ford–Fulkerson Algorithm
More Jackson Annotations
Spring Boot - File Handling
How to Read HTTP Headers in Spring REST Controllers
Java Program to Compute Determinant of a Matrix
Hướng dẫn sử dụng Lớp FilePermission trong java
OAuth2 for a Spring REST API – Handle the Refresh Token in AngularJS
Java Program to Implement Quick Hull Algorithm to Find Convex Hull