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 Adjacency Matrix
Refactoring Design Pattern với tính năng mới trong Java 8
Java Program to Implement Skip List
Tính trừu tượng (Abstraction) trong Java
Java Program to Find Whether a Path Exists Between 2 Given Nodes
Xây dựng ứng dụng Client-Server với Socket trong Java
Error Handling for REST with Spring
A Guide to Concurrent Queues in Java
Concatenating Strings In Java
Java Program to Implement Fenwick Tree
Java Program to Implement LinkedTransferQueue API
Debug a HttpURLConnection problem
Converting a Stack Trace to a String in Java
Getting a File’s Mime Type in Java
Guide to Java OutputStream
What is a POJO Class?
Spring Security Logout
Prevent Brute Force Authentication Attempts with Spring Security
HashSet trong java
Creating a Generic Array in Java
Using a Mutex Object in Java
Java CyclicBarrier vs CountDownLatch
@DynamicUpdate with Spring Data JPA
Java Program to Solve Knapsack Problem Using Dynamic Programming
Java Program to Perform String Matching Using String Library
Checking for Empty or Blank Strings in Java
Extract links from an HTML page
Java Program to Implement Bubble Sort
Mapping Nested Values with Jackson
Spring Boot - Internationalization
Introduction to Java Serialization
Guide to the Volatile Keyword in Java