leetcode 3625

3625: 统计梯形的数目Ⅱ

思路:

  1. 本题 n≤500,我们可以 O(n^2) 枚举所有点对组成的直线,计算直线的斜率和截距。
  2. 把斜率相同的直线放在同一组,可以从中选择一对平行边,作为梯形的顶边和底边。(去除共线)
  3. 第二步把平行四边形重复统计了一次,所以还要减去任意不共线四点组成的平行四边形的个数。(去除共线)

注意++计算梯形个数++ 我们用的是顶边和底边,++计算平行四边形个数++我们用的是对角线。

复制代码
unordered_map<double,map<double,int>> cnt; 
unordered_map<int,map<double,int>> cnt2; 

嵌套写法↑

复制代码
double k=dx? 1.0*dy/dx: DBL_MAX;
double b=dx? 1.0*(y*dx-x*dy)/dx: x;

若 dx = 0(垂直),把 k 标记成 DBL_MAX(一个不可能与任何正常斜率冲突的特大数)

DBL_MAXdouble 类型,它定义在 <cfloat> / <float.h> 里,是 double 能表示的最大有限值(≈1.79769e+308)

dx? 在 C/C++ ,0 被视为 false,非 0 被视为 true

  • dx != 0 时走 A 分支(非垂直)
  • dx == 0 时走 B 分支(垂直)

1.0*dy/dx 强制整个表达式按 double 精度计算,防止"整数除法"把结果截断成整数。

复制代码
int mid=(x+x2+2000)<<16 | (y+y2+2000); 
  • 4 <= points.length <= 500
  • --1000 <= xi, yi <= 1000 (题目设定)

int 一般认为是32bit,高16位为横坐标,低16位为纵坐标->把二维坐标压缩成一个 int

复制代码
class Solution {
public:
    int countTrapezoids(vector<vector<int>>& points) {
        // 经测试,哈希表套 map 比哈希表套哈希表更快(分组后,每一组的数据量比较小,小数据下 map 比哈希表快)
        unordered_map<double,map<double,int>> cnt; // 斜率 -> 截距 -> 梯形个数
        unordered_map<int,map<double,int>> cnt2; // 中点 -> 斜率 -> 平行四边形个数

        int n=points.size();
        for(int i=0;i<n;i++){
            int x=points[i][0],y=points[i][1]; //剔除共线
            for(int j=0;j<i;j++){
                int x2=points[j][0],y2=points[j][1];
                int dx=x-x2,dy=y-y2;
                double k=dx? 1.0*dy/dx: DBL_MAX;
                double b=dx? 1.0*(y*dx-x*dy)/dx: x;
                cnt[k][b]++;
                int mid=(x+x2+2000)<<16 | (y+y2+2000); // 把二维坐标压缩成一个 int
                cnt2[mid][k]++;
            }
        }
        int ans=0;
        for(auto& [_,m] :cnt){
            int s=0;
            for(auto& [_,c] :m){
                ans+=s*c;
                s+=c;
            }
        }

        for(auto& [_,m] :cnt2){
            int s=0;
            for(auto& [_,c] :m){
                ans-=s*c; // 平行四边形会统计两次,减去多统计的一次  
                s+=c;
            }
        }

        return ans;
    }
};
相关推荐
Dillon Dong2 小时前
【风电控制】TI TMS320F28379D 双CPU架构解析与任务分布设计
嵌入式硬件·算法·变流器·风电控制
小羊在睡觉8 小时前
力扣84. 柱状图中最大的矩形
后端·算法·leetcode·golang·go
3DVisionary8 小时前
蓝光三维扫描:医疗制造的精度焦虑怎么解
人工智能·算法·制造·蓝光三维扫描·医疗制造·三维检测·义齿检测
好评笔记8 小时前
机器学习面试八股——常用损失函数
人工智能·深度学习·算法·机器学习·校招
weixin_468466858 小时前
全局与局部注意力机制新手实战指南
人工智能·python·深度学习·算法·自然语言处理·transformer·注意力机制
sheeta19989 小时前
LeetCode 每日一题笔记 日期:2026.05.29 题目:3300. 最小元素
笔记·leetcode
_日拱一卒9 小时前
LeetCode:994腐烂的橘子
java·数据结构·算法·leetcode·深度优先
珂朵莉MM9 小时前
第七届全球校园人工智能算法精英大赛-算法巅峰赛产业命题赛第3赛季优化题--束搜索
人工智能·算法
Omics Pro10 小时前
首个!外源天然产物综合性代谢图谱
数据库·人工智能·算法·机器学习·r语言
voidmort10 小时前
3. 微调(Fine-tuning)与强化学习(RL)的核心思想
python·深度学习·算法