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:
Introduction to Apache Commons Text
Using the Not Operator in If Conditions in Java
Ways to Iterate Over a List in Java
Java Program to Implement Sorted Array
Hướng dẫn Java Design Pattern – Adapter
Java Program to Solve the Fractional Knapsack Problem
ThreadPoolTaskExecutor corePoolSize vs. maxPoolSize
Introduction to Project Reactor Bus
Java Program to Implement Merge Sort Algorithm on Linked List
Checked and Unchecked Exceptions in Java
Java Program to Optimize Wire Length in Electrical Circuit
A Guide to Iterator in Java
Java Program to Implement Sorted Circular Doubly Linked List
Java Program to Implement LinkedList API
Spring 5 Testing with @EnabledIf Annotation
Java Program to Implement Jarvis Algorithm
Lập trình đa luồng với CompletableFuture trong Java 8
Pagination and Sorting using Spring Data JPA
Quick Guide to @RestClientTest in Spring Boot
Từ khóa this và super trong Java
Java Program to Perform Deletion in a BST
Java Program to Implement Stein GCD Algorithm
Java Deep Learning Essentials - Yusuke Sugomori
Java Program to Implement Binary Heap
Working With Maps Using Streams
Giới thiệu Aspect Oriented Programming (AOP)
Java Program to Implement Wagner and Fisher Algorithm for online String Matching
Java Program to Implement Knapsack Algorithm
Adding Parameters to HttpClient Requests
Zipping Collections in Java
Java Program to Implement Depth-limited Search
Chuyển đổi Array sang ArrayList và ngược lại