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 Range Tree
Comparing Dates in Java
Get and Post Lists of Objects with RestTemplate
Count Occurrences of a Char in a String
Spring’s RequestBody and ResponseBody Annotations
Remove All Occurrences of a Specific Value from a List
Reactive Flow with MongoDB, Kotlin, and Spring WebFlux
How to Implement Caching using Adonis.js 5
Java Program to Implement IdentityHashMap API
Java Program to Implement ConcurrentLinkedQueue API
Java Program to Show the Duality Transformation of Line and Point
Java Program to Search Number Using Divide and Conquer with the Aid of Fibonacci Numbers
Configuring a DataSource Programmatically in Spring Boot
HTTP Authentification and CGI/Servlet
Logout in an OAuth Secured Application
Spring Cloud Connectors and Heroku
Guide to the Java Queue Interface
A Guide to JPA with Spring
Java Program to Compute Determinant of a Matrix
Tạo chương trình Java đầu tiên sử dụng Eclipse
Finding area of simple polygon in $O(N)$
Receive email using POP3
Using a List of Values in a JdbcTemplate IN Clause
Spring Boot Change Context Path
Add Multiple Items to an Java ArrayList
Generating Random Dates in Java
Spring AMQP in Reactive Applications
Create a Custom Auto-Configuration with Spring Boot
Spring Boot - Build Systems
Remove the First Element from a List
Lớp HashMap trong Java
An Intro to Spring Cloud Vault