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 Delete a Particular Node in a Tree Without Using Recursion
Java Program to Implement Coppersmith Freivald’s Algorithm
HashSet trong Java hoạt động như thế nào?
Add Multiple Items to an Java ArrayList
Guide to Guava Multimap
Java Program to Find Number of Articulation points in a Graph
Error Handling for REST with Spring
Getting a File’s Mime Type in Java
Java 8 Predicate Chain
Spring Boot - Admin Server
Spring Boot Security Auto-Configuration
Multipart Upload with HttpClient 4
Loại bỏ các phần tử trùng trong một ArrayList như thế nào trong Java 8?
Java 9 Stream API Improvements
New Features in Java 12
Spring Cloud – Tracing Services with Zipkin
Java Program to Implement Park-Miller Random Number Generation Algorithm
Form Validation with AngularJS and Spring MVC
Guide to DelayQueue
Java Program to Evaluate an Expression using Stacks
Java Program to Use the Bellman-Ford Algorithm to Find the Shortest Path
Spring RestTemplate Request/Response Logging
Consuming RESTful Web Services
Encode a String to UTF-8 in Java
Java Program to Implement AVL Tree
Giới thiệu Json Web Token (JWT)
Java Program to Implement the Binary Counting Method to Generate Subsets of a Set
Java Program to Perform String Matching Using String Library
Lớp Properties trong java
Java Program to Implement Sorting of Less than 100 Numbers in O(n) Complexity
Debug a JavaMail Program
Prevent Brute Force Authentication Attempts with Spring Security