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:
Case-Insensitive String Matching in Java
Spring Boot Security Auto-Configuration
Java Program to Implement Max-Flow Min-Cut Theorem
Giới thiệu SOAP UI và thực hiện test Web Service
Call Methods at Runtime Using Java Reflection
Date Time trong Java 8
Convert Character Array to String in Java
Using Custom Banners in Spring Boot
A Guide to @RepeatedTest in Junit 5
Testing an OAuth Secured API with Spring MVC
Java Program to Implement Best-First Search
Một số từ khóa trong Java
An Intro to Spring Cloud Security
Java Program to Implement Maximum Length Chain of Pairs
So sánh ArrayList và LinkedList trong Java
Spring Boot Configuration with Jasypt
Initialize a HashMap in Java
Giới thiệu thư viện Apache Commons Chain
Java Program to Represent Graph Using Linked List
Injecting Prototype Beans into a Singleton Instance in Spring
RestTemplate Post Request with JSON
Chuyển đổi giữa các kiểu dữ liệu trong Java
Java Program to Generate All Pairs of Subsets Whose Union Make the Set
Guide to the Volatile Keyword in Java
Java Program to do a Depth First Search/Traversal on a graph non-recursively
Java – Generate Random String
Immutable Objects in Java
Java Perform to a 2D FFT Inplace Given a Complex 2D Array
Why String is Immutable in Java?
Tiêu chuẩn coding trong Java (Coding Standards)
Spring Data JPA and Null Parameters
Handling URL Encoded Form Data in Spring REST