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:
Constructor Injection in Spring with Lombok
Chương trình Java đầu tiên
Tạo chương trình Java đầu tiên sử dụng Eclipse
Java Program to Perform Optimal Paranthesization Using Dynamic Programming
Remove HTML tags from a file to extract only the TEXT
Introduction to the Java NIO2 File API
A Guide to the ViewResolver in Spring MVC
Java Program to Find the Shortest Path from Source Vertex to All Other Vertices in Linear Time
So sánh HashMap và Hashtable trong Java
Hướng dẫn sử dụng biểu thức chính quy (Regular Expression) trong Java
Java Program to Print the Kind of Rotation the AVL Tree is Undergoing
Hướng dẫn sử dụng Java Reflection
Biến trong java
Hướng dẫn Java Design Pattern – Intercepting Filter
Java Program to Implement Johnson’s Algorithm
Một số nguyên tắc, định luật trong lập trình
The Spring @Controller and @RestController Annotations
Java Program to Implement Direct Addressing Tables
Java Program to Implement the Edmond’s Algorithm for Maximum Cardinality Matching
Remove All Occurrences of a Specific Value from a List
Convert String to int or Integer in Java
Java Program to Compute Discrete Fourier Transform Using Naive Approach
Java Program for Douglas-Peucker Algorithm Implementation
Jackson JSON Views
Java – String to Reader
Guava CharMatcher
Java Collections Interview Questions
Immutable ArrayList in Java
Introduction to Eclipse Collections
Java Program to Implement Ternary Search Algorithm
Java Program to Perform Insertion in a 2 Dimension K-D Tree
Spring Boot Security Auto-Configuration