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 Implement SynchronosQueue API
REST Web service: Basic Authentication trong Jersey 2.x
Hướng dẫn sử dụng luồng vào ra ký tự trong Java
Guide to Mustache with Spring Boot
Java Program to Perform Partition of an Integer in All Possible Ways
Jackson – Unmarshall to Collection/Array
Spring Boot - Build Systems
Spring Security 5 for Reactive Applications
Java Program to Implement ConcurrentLinkedQueue API
Java Program to Implement Bucket Sort
Java Program to Check Cycle in a Graph using Graph traversal
Tạo số và chuỗi ngẫu nhiên trong Java
Stack Memory and Heap Space in Java
Exploring the Spring Boot TestRestTemplate
Annotation trong Java 8
Java – Get Random Item/Element From a List
Java Program to Test Using DFS Whether a Directed Graph is Strongly Connected or Not
Guide to ThreadLocalRandom in Java
HashMap trong Java hoạt động như thế nào?
HTTP Authentification and CGI/Servlet
Java Program to Implement LinkedHashMap API
Java Program to Perform Naive String Matching
Command-Line Arguments in Java
Spring MVC Custom Validation
Hướng dẫn Java Design Pattern – Visitor
Life Cycle of a Thread in Java
Java Program to Perform integer Partition for a Specific Case
Java Program to Perform Inorder Non-Recursive Traversal of a Given Binary Tree
Generating Random Numbers in a Range in Java
Java Program to Check whether Graph is a Bipartite using BFS
Java Program to Create a Random Graph Using Random Edge Generation
How to Break from Java Stream forEach