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:
Spring Boot - Web Socket
Java Program to Implement Quick Sort Using Randomization
Java Program to Describe the Representation of Graph using Incidence List
Hướng dẫn Java Design Pattern – Adapter
The Registration Process With Spring Security
Wiring in Spring: @Autowired, @Resource and @Inject
Control Structures in Java
Giới thiệu SOAP UI và thực hiện test Web Service
Guide to Character Encoding
Java 8 Streams peek() API
Logout in an OAuth Secured Application
File Upload with Spring MVC
Java Timer
Java Program to Implement Stack API
Spring Boot: Customize Whitelabel Error Page
Function trong Java 8
Java Program to Implement Range Tree
ETL with Spring Cloud Data Flow
Java Program to Create a Random Graph Using Random Edge Generation
REST Web service: Tạo ứng dụng Java RESTful Client với Jersey Client 2.x
Java Program to Perform Addition Operation Using Bitwise Operators
Spring Boot - Batch Service
Tính đóng gói (Encapsulation) trong java
Configure a Spring Boot Web Application
Shuffling Collections In Java
Spring Data MongoDB Transactions
Java Program to Implement Hash Tables chaining with Singly Linked Lists
Java Program to Implement Lloyd’s Algorithm
Guide to the Fork/Join Framework in Java
ArrayList trong java
Java Web Services – JAX-WS – SOAP
Java Program to Implement Repeated Squaring Algorithm