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:
Lập trình đa luồng với CompletableFuture trong Java 8
Hướng dẫn sử dụng Java String, StringBuffer và StringBuilder
Spring MVC Setup with Kotlin
Java Program to Check whether Graph is Biconnected
Java Program to Generate All Possible Combinations of a Given List of Numbers
Send email with JavaMail
Java Program to Perform Partition of an Integer in All Possible Ways
Java Program to Implement CopyOnWriteArrayList API
Java Program to Perform Preorder Recursive Traversal of a Given Binary Tree
Java Program to Implement Uniform-Cost Search
Java Program to Implement Hash Tables Chaining with List Heads
4 tính chất của lập trình hướng đối tượng trong Java
Java Program to implement Array Deque
Display Auto-Configuration Report in Spring Boot
Getting the Size of an Iterable in Java
Java InputStream to String
Java Program to Perform Addition Operation Using Bitwise Operators
Java Program to Perform Arithmetic Operations on Numbers of Size
Apache Tiles Integration with Spring MVC
Spring Boot - Admin Server
Java Program to Implement AVL Tree
Hướng dẫn Java Design Pattern – State
Calling Stored Procedures from Spring Data JPA Repositories
Wiring in Spring: @Autowired, @Resource and @Inject
Remove All Occurrences of a Specific Value from a List
Annotation trong Java 8
Spring Boot - Code Structure
Java Program to Use Above Below Primitive to Test Whether Two Lines Intersect
Java Program to Implement TreeSet API
Guide to PriorityBlockingQueue in Java
Custom JUnit 4 Test Runners
Spring WebClient Requests with Parameters