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:
Serialization và Deserialization trong java
Spring Boot with Multiple SQL Import Files
Từ khóa throw và throws trong Java
Java NIO2 Path API
Java Program to find the number of occurrences of a given number using Binary Search approach
Lập trình mạng với java
A Guide to Concurrent Queues in Java
The Basics of Java Security
Tạo ứng dụng Java RESTful Client không sử dụng 3rd party libraries
Rest Web service: Filter và Interceptor với Jersey 2.x (P1)
Introduction to the Functional Web Framework in Spring 5
Java Program to Find a Good Feedback Vertex Set
Java Program to Implement Hash Tables
Java Program to Implement Cubic convergence 1/pi Algorithm
A Guide to ConcurrentMap
Inject Parameters into JUnit Jupiter Unit Tests
Java Program to Implement Shell Sort
Spring Data JPA @Modifying Annotation
Guide to Java 8’s Collectors
A Guide to @RepeatedTest in Junit 5
Filtering and Transforming Collections in Guava
Lập trình đa luồng trong Java (Java Multi-threading)
Functional Interfaces in Java 8
Introduction to Spliterator in Java
The Registration API becomes RESTful
New Features in Java 12
Phương thức forEach() trong java 8
Java – Reader to Byte Array
Java Program to Implement Queue using Two Stacks
New Features in Java 9
Convert String to int or Integer in Java
Generic Constructors in Java