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 Solve the Fractional Knapsack Problem
Immutable Objects in Java
Merging Two Maps with Java 8
Prevent Cross-Site Scripting (XSS) in a Spring Application
Logging in Spring Boot
Java Program to Perform Addition Operation Using Bitwise Operators
Java Program to Perform Left Rotation on a Binary Search Tree
Introduction to Spring MVC HandlerInterceptor
Using the Map.Entry Java Class
Jackson Ignore Properties on Marshalling
Java Program to Implement Rope
Java Program to Implement CopyOnWriteArraySet API
Java Program to Construct K-D Tree for 2 Dimensional Data
Guide to java.util.Formatter
Introduction to the Java NIO Selector
Một số tính năng mới về xử lý ngoại lệ trong Java 7
Weak References in Java
Semaphore trong Java
Custom Error Pages with Spring MVC
Java Program to Implement Word Wrap Problem
Java Program to Implement VList
Bootstrapping Hibernate 5 with Spring
Custom Thread Pools In Java 8 Parallel Streams
Exploring the Spring Boot TestRestTemplate
Lập trình hướng đối tượng (OOPs) trong java
Java Program to Implement Cubic convergence 1/pi Algorithm
Java Program to Compute the Volume of a Tetrahedron Using Determinants
Java Program to implement Priority Queue
Java Program to Implement Affine Cipher
Check if there is mail waiting
Hướng dẫn Java Design Pattern – Dependency Injection
Hướng dẫn Java Design Pattern – Bridge