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

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.对公式中的计算采用部分计算,尽量避免除法运算,因为除法经常精度上会出问题,而这题的本质并不是精确的计算出三角形的面积或边,只是根据一定的条件能判断出三点是否符合一定的性质即可,太厉害了!

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

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

你可能感兴趣的:(代码)