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:
Spring Boot - Batch Service
Java Program to Check Whether Topological Sorting can be Performed in a Graph
Java Program to Implement Wagner and Fisher Algorithm for online String Matching
Java Program to Implement Ternary Heap
Java Program to Implement ArrayList API
Logout in an OAuth Secured Application
Kết hợp Java Reflection và Java Annotations
Guide to the Fork/Join Framework in Java
Java Program to Implement the linear congruential generator for Pseudo Random Number Generation
Java Program to Implement ConcurrentHashMap API
Java Program to Implement Iterative Deepening
Removing all Nulls from a List in Java
PolandBall and Polygon
Java Program to Implement Hash Tables Chaining with List Heads
Java Program to Check the Connectivity of Graph Using BFS
Ignore Null Fields with Jackson
Giới thiệu Google Guice – Injection, Scope
Java Program to Find the Shortest Path from Source Vertex to All Other Vertices in Linear Time
Spring 5 Functional Bean Registration
Java Program to Implement Gauss Seidel Method
Tránh lỗi NullPointerException trong Java như thế nào?
Constructor Dependency Injection in Spring
Java Program to Implement Splay Tree
Java Program to Implement Fermat Factorization Algorithm
Guide to @JsonFormat in Jackson
Một số từ khóa trong Java
Intro to the Jackson ObjectMapper
Java Program for Topological Sorting in Graphs
Java – Try with Resources
Java Program to Implement CopyOnWriteArrayList API
A Guide to System.exit()
Sending Emails with Java