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:
Implementing a Binary Tree in Java
How to Set TLS Version in Apache HttpClient
A Guide to System.exit()
Spring 5 WebClient
An Intro to Spring Cloud Contract
New Features in Java 9
HashSet trong java
Giới thiệu thư viện Apache Commons Chain
Java Program to Implement Double Ended Queue
Java Program to Find the GCD and LCM of two Numbers
Java Program to Implement VList
Java Program to implement Bit Set
Spring’s RequestBody and ResponseBody Annotations
Guide to the Java TransferQueue
SOAP Web service: Authentication trong JAX-WS
Java Program to Implement Karatsuba Multiplication Algorithm
Marker Interface trong Java
Multipart Upload with HttpClient 4
Java Program to Implement the Hungarian Algorithm for Bipartite Matching
Hướng dẫn Java Design Pattern – Visitor
HashSet trong Java hoạt động như thế nào?
Java Program to Generate Random Numbers Using Middle Square Method
Use Liquibase to Safely Evolve Your Database Schema
Java Program to Implement Bresenham Line Algorithm
Một số ký tự đặc biệt trong Java
Spring Boot Change Context Path
Java Program to Implement RoleList API
XML-Based Injection in Spring
Java Program to Implement Quick Sort Using Randomization
Spring Security Authentication Provider
Lập trình đa luồng trong Java (Java Multi-threading)
Spring Boot - Zuul Proxy Server and Routing