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:
How to Read HTTP Headers in Spring REST Controllers
Giới thiệu Design Patterns
Netflix Archaius with Various Database Configurations
JUnit 5 @Test Annotation
Creating a Web Application with Spring 5
Java Program to Perform Partition of an Integer in All Possible Ways
Test a REST API with Java
Control Structures in Java
Java Program to Find Minimum Element in an Array using Linear Search
HandlerAdapters in Spring MVC
Java Program to Check for balanced parenthesis by using Stacks
Tạo số và chuỗi ngẫu nhiên trong Java
Java Program to Implement Bubble Sort
Rest Web service: Filter và Interceptor với Jersey 2.x (P2)
Debug a HttpURLConnection problem
Changing Annotation Parameters At Runtime
Java Program to Solve a Matching Problem for a Given Specific Case
Reactive WebSockets with Spring 5
Giới thiệu Json Web Token (JWT)
Java Program to Implement Affine Cipher
Java Program to Perform Complex Number Multiplication
The DAO with JPA and Spring
JPA/Hibernate Persistence Context
Jackson Unmarshalling JSON with Unknown Properties
The DAO with Spring and Hibernate
Creating a Custom Starter with Spring Boot
Làm thế nào tạo instance của một class mà không gọi từ khóa new?
Spring Cloud – Securing Services
Java Program to Perform Searching in a 2-Dimension K-D Tree
Guide to CountDownLatch in Java
Java Program to Implement Double Ended Queue
Spring Boot - Code Structure