JavaInterview JavaInterview
首页
指南
分类
标签
归档
  • CSDN (opens new window)
  • 文档集合 (opens new window)
  • 系统架构 (opens new window)
  • 微信号 (opens new window)
  • 公众号 (opens new window)

『Java面试+Java学习』
首页
指南
分类
标签
归档
  • CSDN (opens new window)
  • 文档集合 (opens new window)
  • 系统架构 (opens new window)
  • 微信号 (opens new window)
  • 公众号 (opens new window)
  • 指南
  • 简历

  • Java

  • 面试

  • 算法

  • algorithm
  • leetcode
JavaInterview.cn
2022-10-19
目录

最大三角形面积Java

文章发布较早,内容可能过时,阅读注意甄别。

# 题目

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

示例: 输入: points = [[0,0],[0,1],[1,0],[0,2],[2,0]] 输出: 2 解释: 这五个点如下图所示。组成的橙色三角形是最大的,面积为2。

注意:

  • 3 <= points.length <= 50.
  • 不存在重复的点。
  • -50 <= points[i][j] <= 50.
  • 结果误差值在 10^-6 以内都认为是正确答案。

# 思路

//  枚举 + 数学 向量叉积

//三个点构成两个共起点的向量。
//两个向量可作平行四边形,面积是它们构成的行列式值的绝对值。
//三角形面积是平行四边形面积的一半。
//不需要回头:如果某个点p1曾被选中作为起点,那么在p2作为起点时,不需要考虑p1作为终点的情况。
//理由:设第三个点p3,向量p1p2、p1p3构成的三角形和向量p2p1、p2p3构成的三角形是同一个。

# 解法


class Solution {
    //  枚举 + 数学 向量叉积 
    public double largestTriangleArea(int[][] points) {
        int n = points.length;
        double res = 0;
        for (int i = 0 ; i < n - 2 ; i++){
            int a[] = points[i];
            for (int j = i + 1; j < n - 1 ; j++){
                int b[] = points[j];
                for (int k = j + 1 ; k < n ; k++){
                    int c[] = points[k];
                    int xAB = b[0] - a[0];
                    int yAB = b[1] - a[1];
                    int xAC = c[0] - a[0];
                    int yAC = c[1] - a[1];
                    if (Math.abs(xAB * yAC - xAC * yAB) / 2.0 > res)
                        res =Math.abs(xAB * yAC - xAC * yAB)/ 2.0;

                }
            }
        }
        return res;
    }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25

# 总结

  • 分析出几种情况,然后分别对各个情况实现
微信 支付宝
最近更新
01
1633. 各赛事的用户注册率 Java
07-02
02
1636. 按照频率将数组升序排序 Java
07-02
03
1639. 通过给定词典构造目标字符串的方案数 Java
07-02
更多文章>
Theme by Vdoing | Copyright © 2019-2025 JavaInterview.cn
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式