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:
Java Program to Generate a Sequence of N Characters for a Given Specific Case
LIKE Queries in Spring JPA Repositories
Spring Data JPA @Query
Java CyclicBarrier vs CountDownLatch
Java Program to Implement the String Search Algorithm for Short Text Sizes
Introduction to Spring Data JDBC
Java Program to Generate All Pairs of Subsets Whose Union Make the Set
Java Program to Implement Multi-Threaded Version of Binary Search Tree
Java Web Services – JAX-WS – SOAP
Java Program to Generate a Graph for a Given Fixed Degree Sequence
Hướng dẫn Java Design Pattern – Interpreter
Java Program to Implement Repeated Squaring Algorithm
The Thread.join() Method in Java
Mệnh đề if-else trong java
Java Program to Perform Sorting Using B-Tree
Interface trong Java 8 – Default method và Static method
Java Program to Implement Double Order Traversal of a Binary Tree
Test a REST API with Java
Giới thiệu SOAP UI và thực hiện test Web Service
Logging in Spring Boot
String Operations with Java Streams
Hướng dẫn sử dụng Java Generics
Java Program to Show the Duality Transformation of Line and Point
Converting String to Stream of chars
Inheritance with Jackson
Java 8 Predicate Chain
Spring Boot - Runners
Java Optional as Return Type
Java Program to Implement Queue using Two Stacks
Spring Boot: Customize Whitelabel Error Page
Java Program to Check if an UnDirected Graph is a Tree or Not Using DFS
Sử dụng JDBC API thực thi câu lệnh truy vấn dữ liệu