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 Check whether Graph is a Bipartite using 2 Color Algorithm
Java Program to Implement Stein GCD Algorithm
Java Program to Implement Dijkstra’s Algorithm using Queue
A Guide to Java HashMap
XML Serialization and Deserialization with Jackson
Create a Custom Auto-Configuration with Spring Boot
Java Program to Solve the Fractional Knapsack Problem
Using a Mutex Object in Java
Refactoring Design Pattern với tính năng mới trong Java 8
HttpAsyncClient Tutorial
@Before vs @BeforeClass vs @BeforeEach vs @BeforeAll
Using the Not Operator in If Conditions in Java
Java Program to Implement K Way Merge Algorithm
Java Program to Implement Fenwick Tree
Send email with SMTPS (eg. Google GMail)
How to Replace Many if Statements in Java
Introduction to Spring Cloud Rest Client with Netflix Ribbon
Java Program to Implement Doubly Linked List
Từ khóa throw và throws trong Java
Jackson Ignore Properties on Marshalling
Java Program to Use the Bellman-Ford Algorithm to Find the Shortest Path
Java Program to Generate Random Numbers Using Middle Square Method
Java Program to Perform Finite State Automaton based Search
Apache Tiles Integration with Spring MVC
Java Stream Filter with Lambda Expression
Java Program to Generate All Possible Subsets with Exactly k Elements in Each Subset
Java Program to Implement CountMinSketch
Mapping a Dynamic JSON Object with Jackson
Collection trong java
Giới thiệu Swagger – Công cụ document cho RESTfull APIs
Spring’s RequestBody and ResponseBody Annotations
Introduction to Spring Method Security