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:
Jackson – Marshall String to JsonNode
Java Program to Implement Vector API
Spring Boot - Apache Kafka
Tìm hiểu cơ chế Lazy Evaluation của Stream trong Java 8
Introduction to Spring Security Expressions
HttpClient Basic Authentication
Java InputStream to String
Java Program to Find MST (Minimum Spanning Tree) using Kruskal’s Algorithm
Java – Write to File
Java IO vs NIO
ClassNotFoundException vs NoClassDefFoundError
Converting String to Stream of chars
Handle EML file with JavaMail
XML-Based Injection in Spring
Java Program to Generate All Possible Subsets with Exactly k Elements in Each Subset
Introduction to Java 8 Streams
Spring RestTemplate Error Handling
Spring MVC Content Negotiation
Spring Boot Change Context Path
Java NIO2 Path API
Spring Boot - Build Systems
Java Program to Implement Kosaraju Algorithm
Java Program to Find the Median of two Sorted Arrays using Binary Search Approach
Java Program to Check if an UnDirected Graph is a Tree or Not Using DFS
Spring Data Reactive Repositories with MongoDB
Java Program to Implement ScapeGoat Tree
Java Program to Apply Above-Below-on Test to Find the Position of a Point with respect to a Line
Redirect to Different Pages after Login with Spring Security
Java Program to Evaluate an Expression using Stacks
Java Program to Implement Circular Singly Linked List
Java Program to Implement HashMap API
Java Program to Implement Gale Shapley Algorithm