我发现我的代码就像小孩子写的


long s = 0;
for (int i = 0; i < 3; i++) {
s += (x[i] * y[(i + 1) % 3] - y[i] * x[(i + 1) % 3]);
}
if (s == 0) {
out.print("not a triangle");
} else {
long[] l = new long[3];
for (int i = 0; i < 3; i++) {
l[i] = (x[i] - x[(i + 1) % 3]) * (x[i] - x[(i + 1) % 3]) + (y[i] - y[(i + 1) % 3]) * (y[i] - y[(i + 1) % 3]);
}
Arrays.sort(l);
if (l[0] == l[1] || l[1] == l[2]) {
out.print("isosceles ");
} else {
out.print("scalene ");
}
long[] t = new long[3];
for (int i = 0; i < 3; i++) {
t[i] = (x[(i + 1) % 3] - x[i]) * (x[(i - 1 + 3) % 3] - x[i]) + (y[(i + 1) % 3] - y[i]) * (y[(i - 1 + 3) % 3] - y[i]);
}
Arrays.sort(t);
if (t[0] == 0) {
out.print("right");
} else {
if (t[0] < 0) {
out.print("obtuse");
} else {
out.print("acute");
}
}


这是一个判断三角形直角,或者是否是三角形,是否等腰等边的代码,我之前的代码和他们比起来,我就像小孩写的一样。。。。
第一个是根据斜率计算是否是同一三角形
第二个是根据三条边计算公式判断时候等腰等边或者非等腰等边
第三个是根据三角形任意角的cos判断是否是直角,锐角或钝角三角形,
这个程序厉害的地方在于:
1.for循环用得很巧
2.对公式中的计算采用部分计算,尽量避免除法运算,因为除法经常精度上会出问题,而这题的本质并不是精确的计算出三角形的面积或边,只是根据一定的条件能判断出三点是否符合一定的性质即可,太厉害了!

之前还傻傻的计算面积什么的,完全没必要,不过上面这种判断是否是直角,锐角或钝角三角形的方法实在是绕了很多步,我也是用公式推出来的,咋一看还真看不出来这个代码写了什么意思。

现在终于明白了为什么要大量的阅读优秀程序员的代码。。。。。。。可能我理解的还不够深入,如果没有阅读其他优秀程序员的代码,自己的代码风格和水平始终在那里得不到提高,阅读代码是一种艺术,也是一种享受和提高。。。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值