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:
Validate email address exists or not by Java Code
HashMap trong Java hoạt động như thế nào?
Spring – Injecting Collections
Java Program to Perform Preorder Recursive Traversal of a Given Binary Tree
Inject Parameters into JUnit Jupiter Unit Tests
Java Program to Implement ConcurrentHashMap API
wait() and notify() Methods in Java
Java Program to Implement Fermat Factorization Algorithm
Hướng dẫn Java Design Pattern – MVC
Java Program to Find Hamiltonian Cycle in an UnWeighted Graph
Guide to the Java Clock Class
Java Program to Perform Preorder Non-Recursive Traversal of a Given Binary Tree
Spring Security – Reset Your Password
Intro to the Jackson ObjectMapper
Handling URL Encoded Form Data in Spring REST
Auditing with JPA, Hibernate, and Spring Data JPA
Simple Single Sign-On with Spring Security OAuth2
Introduction to the Functional Web Framework in Spring 5
An Intro to Spring Cloud Security
Java Program to Implement Fermat Primality Test Algorithm
Spring NoSuchBeanDefinitionException
Getting Started with Stream Processing with Spring Cloud Data Flow
Java Program to Generate All Possible Combinations Out of a, b, c, d, e
Spring Boot - Admin Client
Java Program to Implement the Alexander Bogomolny’s UnOrdered Permutation Algorithm for Elements Fro...
Optional trong Java 8
A Guide to JPA with Spring
JUnit5 @RunWith
Tiêu chuẩn coding trong Java (Coding Standards)
Quick Guide to Spring MVC with Velocity
Giới thiệu Google Guice – Dependency injection (DI) framework
Java Program to Compute Determinant of a Matrix