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:
Tránh lỗi ConcurrentModificationException trong Java như thế nào?
Introduction to Eclipse Collections
Toán tử trong java
Java Program to Generate Random Numbers Using Middle Square Method
Lớp Arrarys trong Java (Arrays Utility Class)
Apache Commons Collections OrderedMap
Java Program to Implement Rolling Hash
Spring MVC Custom Validation
Stack Memory and Heap Space in Java
Java Program to Find the Vertex Connectivity of a Graph
Mapping a Dynamic JSON Object with Jackson
Java Program to Check if it is a Sparse Matrix
The StackOverflowError in Java
A Quick Guide to Spring MVC Matrix Variables
Functional Interfaces in Java 8
HttpClient 4 Cookbook
Java Program to implement Bi Directional Map
Sorting in Java
ETL with Spring Cloud Data Flow
Finding area of simple polygon in $O(N)$
Spring Boot - OAuth2 with JWT
Java Program to Implement Hash Tables with Quadratic Probing
Returning Image/Media Data with Spring MVC
Java Program to Solve any Linear Equations
Spring RestTemplate Error Handling
Exception Handling in Java
Thao tác với tập tin và thư mục trong Java
Java Program to Implement Quick Hull Algorithm to Find Convex Hull
Spring Data JPA Delete and Relationships
Java Program to Implement Johnson’s Algorithm
Pagination and Sorting using Spring Data JPA
Giới thiệu java.io.tmpdir