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:
PolandBall and Polygon
Java Program to Implement Affine Cipher
Java Program to Create a Random Graph Using Random Edge Generation
Giới thiệu Aspect Oriented Programming (AOP)
Java Program to Represent Graph Using Adjacency List
Constructor Dependency Injection in Spring
Hướng dẫn Java Design Pattern – Service Locator
Giới thiệu Design Patterns
Introduction to Spring Security Expressions
Converting Between an Array and a Set in Java
Jackson – Change Name of Field
Java toString() Method
Java Program to Implement Sieve Of Eratosthenes
Java Program to Find Minimum Element in an Array using Linear Search
Java Program to Implement Word Wrap Problem
How to Get All Dates Between Two Dates?
Read an Outlook MSG file
Mệnh đề Switch-case trong java
Map to String Conversion in Java
Pagination and Sorting using Spring Data JPA
Convert Hex to ASCII in Java
Java Program to Implement Gift Wrapping Algorithm in Two Dimensions
Vòng lặp for, while, do-while trong Java
Tìm hiểu cơ chế Lazy Evaluation của Stream trong Java 8
Spring Boot - Interceptor
So sánh ArrayList và LinkedList trong Java
Converting Java Date to OffsetDateTime
Java Program to Implement Stein GCD Algorithm
Spring Cloud AWS – S3
Java – Write an InputStream to a File
Introduction to PCollections
Java Perform to a 2D FFT Inplace Given a Complex 2D Array