gpt4 book ai didi

java - 为什么我的 SSS 三角形求解器给出了一个完全错误的答案?

转载 作者:塔克拉玛干 更新时间:2023-11-03 05:40:31 26 4
gpt4 key购买 nike

所以我得到了一个项目,在这个项目中,我必须编写一个 Java 程序来返回三角形三边之间的角度,并将这三边作为方法的参数。有一个数学公式可以用来推导出我们可以使用的方程,称为余弦定律,给定三角形 a、b 和 c 的边,c^2 = a^2 + b^2 - 2ab * cos(C) 其中 C 是边 a 和 b 之间的某个角度。我们可以分离角度 C 并得到方程 arccos((-c^2 + a^2 + b^2)/2ab) = C。数学很简单,而且很容易用 Java 实现,但是当我输入边 3、4、5 时,应该产生 90、30、60 的输出,我得到角度 53.130102、36.86989、90.0。这些绝对不是毕达哥拉斯三元组的角度,例如 3、4、5。有人知道我哪里错了吗?

代码:

import static java.lang.Math.sqrt; 
import static java.lang.Math.acos;
import static java.lang.Math.pow;
import static java.lang.Math.PI;

class Main {
public static void main(String[] args) {

anglesFinder(3, 4, 5);

}

public static void anglesFinder(int a, int b, int c) {

double alpha;
double beta;
double gamma;
alpha = (double) Math.acos((Math.pow(b, 2) + Math.pow(c, 2) - Math.pow(a, 2)) / (2 * c * b));
beta = (double) Math.acos((Math.pow(a, 2) + Math.pow(c, 2) - Math.pow(b, 2)) / (2 * a * c));
gamma = (double) Math.acos((Math.pow(a, 2) + Math.pow(b, 2) - Math.pow(c, 2)) / (2 * a * b));
System.out.println("angle between a & b is: " + (beta * (180 / Math.PI)));
System.out.println("angle between a & c is: " + (alpha * (180 / Math.PI)));
System.out.println("angle between b & c is: " + (gamma * (180 / Math.PI)));
}
}

最佳答案

你的程序是正确的,但你是错误的。对于(比例)长度为 1、sqrt(3)/2(约 0.866)和 2 的边的直角三角形,预期的角度为 30、60 和 90 度,这不会缩放到长度 3、4、和 5.

我的计算器给出 53.130102 度的余弦值约为 0.6,而 36.86989 度的余弦值约为 0.8,这与长度 3、4 和 5 相匹配。

关于java - 为什么我的 SSS 三角形求解器给出了一个完全错误的答案?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58308232/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com