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:
Java Program to Give an Implementation of the Traditional Chinese Postman Problem
Receive email using POP3
Logout in an OAuth Secured Application
Assert an Exception is Thrown in JUnit 4 and 5
Java CyclicBarrier vs CountDownLatch
Java Program to Generate a Sequence of N Characters for a Given Specific Case
Java Program to Implement CountMinSketch
Java Program to Implement Segment Tree
Refactoring Design Pattern với tính năng mới trong Java 8
Java Program to Find Minimum Element in an Array using Linear Search
Java Program to Implement TreeSet API
Java Program to Optimize Wire Length in Electrical Circuit
Java Program to Implement Hamiltonian Cycle Algorithm
Spring Boot - Enabling HTTPS
Java Program to implement Associate Array
Model, ModelMap, and ModelAndView in Spring MVC
Java Program to Implement Heap Sort Using Library Functions
Simple Single Sign-On with Spring Security OAuth2
@Lookup Annotation in Spring
Hướng dẫn Java Design Pattern – Builder
Xử lý ngoại lệ đối với trường hợp ghi đè phương thức trong java
Mapping Nested Values with Jackson
Java Program to Implement Knapsack Algorithm
Spring Security Remember Me
Hướng dẫn sử dụng luồng vào ra nhị phân trong Java
Java equals() and hashCode() Contracts
Java Program to Create a Random Linear Extension for a DAG
Java Program to Evaluate an Expression using Stacks
Deque và ArrayDeque trong Java
Quick Guide to Spring MVC with Velocity
MyBatis with Spring
Default Password Encoder in Spring Security 5