我試圖計算與頂點的三角形如何避免在這個三角形面積計算中的舍入誤差?
{{0,1000000000},{1,0},{0,-1000000000}}
很容易看出,這個三角形的面積應該是10億的區域,但是當我嘗試使用任何海倫公式來計算在Java中區或鞋帶公式,我得到0的地區。
我很確定這是由於使用double
s時的舍入錯誤,但我不確定如何繼續。任何指針?
計劃:
private static double areaShoelace(int[][] v) {
return 0.5 * Math.abs(v[0][0]*v[1][1] + v[1][0]*v[2][1] + v[2][0]*v[0][1] +
v[1][0]*v[0][1] + v[2][0]*v[1][1] + v[0][0]*v[2][1]);
}
private static double areaHeron(double a, double b, double c) {
double p = (a + b + c)/2.0d;
return Math.sqrt(p * (p - a) * (p - b) * (p - c));
}
private static double length(int[] a, int [] b) {
return Math.hypot(a[0] - b[0], a[1] - b[1]);
}
public static void main(String[] args) {
int[][] tri = new int[][]{{0,1000000000},{1,0},{0,-1000000000}};
System.out.println(areaShoelace(tri));
System.out.println(areaHeron(length(tri[0], tri[1]), length(tri[1],tri[2]), length(tri[0],tri[2])));
}
輸出:
0.0
0.0
你看過這個問題:「Java中float和double的包含範圍是什麼?」這可能會對您的問題有所瞭解。 http://stackoverflow.com/questions/1650505/what-is-the-inclusive-range-of-float-and-double-in-java – Alos
即使數字較小,您的'areaShoelace()'仍然爲0。 –