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 TreeMap vs HashMap
Map Interface trong java
Java Program to Implement Stein GCD Algorithm
Vấn đề Nhà sản xuất (Producer) – Người tiêu dùng (Consumer) và đồng bộ hóa các luồng trong Java
Posting with HttpClient
Spring WebClient Requests with Parameters
Biểu thức Lambda trong Java 8 – Lambda Expressions
Java 8 Streams peek() API
Java Program to Create a Balanced Binary Tree of the Incoming Data
Java Program to Find a Good Feedback Edge Set in a Graph
Java Program to Create a Random Linear Extension for a DAG
Spring Security – security none, filters none, access permitAll
Introduction to the Java NIO Selector
Hướng dẫn Java Design Pattern – State
Java Program to Encode a Message Using Playfair Cipher
Java Program to Find All Pairs Shortest Path
Convert a Map to an Array, List or Set in Java
Java Program to Perform Preorder Recursive Traversal of a Given Binary Tree
Java Program to Implement Multi-Threaded Version of Binary Search Tree
Guide to Character Encoding
A Quick JUnit vs TestNG Comparison
Create Java Applet to Simulate Any Sorting Technique
@Lookup Annotation in Spring
Pagination and Sorting using Spring Data JPA
Spring Security Logout
Error Handling for REST with Spring
Java Program to Implement Floyd Cycle Algorithm
Java Program to Solve Knapsack Problem Using Dynamic Programming
Java Program to Implement Range Tree
How to Set TLS Version in Apache HttpClient
Introduction to Spring Cloud OpenFeign
Java Program to Check Cycle in a Graph using Graph traversal