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:
Giới thiệu về Stream API trong Java 8
Java Program to Implement Graham Scan Algorithm to Find the Convex Hull
Java TreeMap vs HashMap
Java Program to Create a Minimal Set of All Edges Whose Addition will Convert it to a Strongly Conne...
Java Program to Implement the Schonhage-Strassen Algorithm for Multiplication of Two Numbers
Java Program to Perform Inorder Recursive Traversal of a Given Binary Tree
Get and Post Lists of Objects with RestTemplate
Java Program to Represent Graph Using 2D Arrays
Guide to CountDownLatch in Java
Java 8 StringJoiner
Java Program to implement Dynamic Array
Assert an Exception is Thrown in JUnit 4 and 5
Hướng dẫn sử dụng biểu thức chính quy (Regular Expression) trong Java
Java Program to Implement Floyd-Warshall Algorithm
Spring Boot - Application Properties
Quick Guide to Spring MVC with Velocity
Java Program to Check the Connectivity of Graph Using DFS
Java Program to find the peak element of an array using Binary Search approach
Custom Error Pages with Spring MVC
Java Program to Implement Brent Cycle Algorithm
Java Program to Perform Inorder Non-Recursive Traversal of a Given Binary Tree
Sending Emails with Java
Java Program to Check if an UnDirected Graph is a Tree or Not Using DFS
Guide to UUID in Java
Java Program to Implement LinkedHashSet API
Hướng dẫn tạo và sử dụng ThreadPool trong Java
Java Program to Perform Addition Operation Using Bitwise Operators
Java Program to Implement Meldable Heap
The Registration API becomes RESTful
LinkedHashSet trong java
Spring Autowiring of Generic Types
Java Program to Implement Circular Doubly Linked List