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:
Disable DNS caching
Java – Write to File
Thực thi nhiều tác vụ cùng lúc như thế nào trong Java?
Java Program to Find k Numbers Closest to Median of S, Where S is a Set of n Numbers
How to Get All Dates Between Two Dates?
Spring Security – Reset Your Password
Spring Security Logout
Collection trong java
Java Program to Generate All Possible Combinations of a Given List of Numbers
Java Program to Check Multiplicability of Two Matrices
A Guide to LinkedHashMap in Java
Một số nguyên tắc, định luật trong lập trình
Java Program to Search Number Using Divide and Conquer with the Aid of Fibonacci Numbers
Java Program to Perform Complex Number Multiplication
HTTP Authentification and CGI/Servlet
Java Program to Implement Floyd Cycle Algorithm
Java Program to Implement Find all Forward Edges in a Graph
Spring Boot - CORS Support
Giới thiệu Google Guice – Dependency injection (DI) framework
Java Program to Implement Floyd-Warshall Algorithm
Java Program to Generate a Random UnDirected Graph for a Given Number of Edges
Deque và ArrayDeque trong Java
Spring Web Annotations
Spring REST with a Zuul Proxy
Handle EML file with JavaMail
Java Program to Implement TreeMap API
Spring Boot - Servlet Filter
Converting Between an Array and a Set in Java
ArrayList trong java
Java Program to Generate a Random Subset by Coin Flipping
Guide to Java OutputStream
Java Program to Represent Linear Equations in Matrix Form