前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >LeetCode 812. 最大三角形面积(坐标面积公式)

LeetCode 812. 最大三角形面积(坐标面积公式)

作者头像
Michael阿明
发布2020-07-13 15:03:15
8570
发布2020-07-13 15:03:15
举报
文章被收录于专栏:Michael阿明学习之路

1. 题目

给定包含多个点的集合,从其中取三个点组成三角形,返回能组成的最大三角形的面积。

代码语言:javascript
复制
示例:
输入: points = [[0,0],[0,1],[1,0],[0,2],[2,0]]
输出: 2
解释: 
这五个点如下图所示。组成的橙色三角形是最大的,面积为2。
在这里插入图片描述
在这里插入图片描述
代码语言:javascript
复制
注意:
3 <= points.length <= 50.
不存在重复的点。
 -50 <= points[i][j] <= 50.
结果误差值在 10^-6 以内都认为是正确答案。

来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/largest-triangle-area 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

在这里插入图片描述
在这里插入图片描述
代码语言:javascript
复制
class Solution {
public:
    double largestTriangleArea(vector<vector<int>>& points) {
        double max_area = 0.0;
        for(int i=0; i< points.size(); i++)
        {
            for(int j=i+1; j<points.size(); j++)
            {
                for(int k=j+1; k<points.size(); k++)
                {
                    //坐标公式:S = |(x1 · y2 - x2 · y1) + (x2 · y3 - x3 · y2) + (x3 · y1 - x1 · y3)| / 2
                    double area = abs((points[i][0]*points[j][1] - points[j][0]*points[i][1])
                                     +(points[j][0]*points[k][1] - points[k][0]*points[j][1])
                                     +(points[k][0]*points[i][1] - points[i][0]*points[k][1])) / 2.0;
                    if(area > max_area)
                        max_area = area;
                }
            }
        }
        return max_area;
    }
};

8 ms 8.8 MB

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020/04/25 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 题目
  • 2. 解题
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档