Leetcode 812. 最大三角形面积
题目
给定包含多个点的集合,从其中取三个点组成三角形,返回能组成的最大三角形的面积。
示例:
输入: points = [[0,0],[0,1],[1,0],[0,2],[2,0]]
输出: 2
解释:
这五个点如下图所示。组成的橙色三角形是最大的,面积为2。
注意:
- 3 <= points.length <= 50.
- 不存在重复的点。
- -50 <= points[i][j] <= 50.
- 结果误差值在10^-6 以内都认为是正确答案。
题解
暴力,枚举所有三角形,计算面积取最大值。
代码
double getArea(vector<int>& p1,vector<int>& p2,vector<int>& p3){
//abs(x1*(y2-y3) + x2*(y3-y1) + x3*(y1-y2))/2;
return abs(p1[0]*(p2[1]-p3[1])+p2[0]*(p3[1]-p1[1])+p3[0]*(p1[1]-p2[1]))/2.0;
}
double largestTriangleArea(vector<vector<int>>& points) {
double maxArea = 0;
int n = points.size();
for(int i=0; i<n; i++){
for(int j=i+1; j<n; j++){
for(int k=j+1; k<n; k++){
maxArea = max(maxArea,getArea(points[i],points[j],points[k]));
}
}
}
return maxArea;
}
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/largest-triangle-area
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。