目录结构
1.题目
给定包含多个点的集合,从其中取三个点组成三角形,返回能组成的最大三角形的面积。
示例:
输入: points = [[0,0],[0,1],[1,0],[0,2],[2,0]]
输出: 2
解释:
这五个点如下图所示。组成的橙色三角形是最大的,面积为2。
注意:
- 3 <= points.length <= 50.
- 不存在重复的点。
- -50 <= points[i][j] <= 50.
- 结果误差值在 10^-6 以内都认为是正确答案。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/largest-triangle-area
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
2.题解
public class Solution812 {
@Test
public void test812() {
int[][] points = {{0, 0}, {0, 1}, {1, 0}, {0, 2}, {2, 0}};
System.out.println(largestTriangleArea(points));
}
public double largestTriangleArea(int[][] points) {
int len = points.length;
double result = 0;
for (int i = 0; i < len; ++i) {
for (int j = i + 1; j < len; ++j) {
for (int k = j + 1; k < len; ++k) {
result = Math.max(result, area(points[i], points[j], points[k]));
}
}
}
return result * 0.5;
}
public double area(int[] p1, int[] p2, int[] p3) {
return Math.abs(p1[0] * p2[1] + p2[0] * p3[1] + p3[0] * p1[1]
- p1[1] * p2[0] - p2[1] * p3[0] - p3[1] * p1[0]);
}
}
- 时间复杂度:
- 空间复杂度: