-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathSlowDiameter_3.java
executable file
·45 lines (38 loc) · 1.27 KB
/
SlowDiameter_3.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
import Jcg.geometry.*;
/**
* Implementation of a quadratic time algorithm for computing a farthest pair of points (giving the diameter),
* based on exhaustive search.
*
* @author Code by Luca Castelli Aleardi (INF421 2018, Ecole Polytechnique)
*
*/
public class SlowDiameter_3 implements Diameter_3 {
/**
* Compute a farthest pair of points realizing the diameter of a set of points in 3D space
*
* @param points the set of points
* @return a pair of farthest points
*/
public Point_3[] findFarthestPair(Point_3[] points) {
if(points.length<2) throw new Error("Error: too few points");
double time = System.currentTimeMillis();
System.out.print("Computing farthest pair: slow computation...");
Point_3[] result=new Point_3[] {points[0], points[1]};
Point_3[] pair;
double distance=0.;
for(int i=0;i<points.length;i++) {
for(int j=i+1;j<points.length;j++) {
double pairDistance=points[i].distanceFrom(points[j]).doubleValue();
pair=new Point_3[] {points[i], points[j]};
if(pairDistance>distance) {
result=pair;
distance=pairDistance;
}
}
}
System.out.println("found diameter " + distance);
System.out.println("in time " + (System.currentTimeMillis() - time));
System.out.println("done");
return result;
}
}