LeetCode 3623.统计梯形的数目 I

给你一个二维整数数组 points,其中 points[i] = [xi, yi] 表示第 i 个点在笛卡尔平面上的坐标。

水平梯形 是一种凸四边形,具有 至少一对 水平边(即平行于 x 轴的边)。两条直线平行当且仅当它们的斜率相同。

返回可以从 points 中任意选择四个不同点组成的 水平梯形 数量。

由于答案可能非常大,请返回结果对 10 9 ^9 9 + 7 取余数后的值。

示例 1:

输入: points = [[1,0],[2,0],[3,0],[2,2],[3,2]]

输出: 3

解释:

有三种不同方式选择四个点组成一个水平梯形:

使用点 [1,0]、[2,0]、[3,2] 和 [2,2]。

使用点 [2,0]、[3,0]、[3,2] 和 [2,2]。

使用点 [1,0]、[3,0]、[3,2] 和 [2,2]。

示例 2:

输入: points = [[0,0],[1,0],[0,1],[2,1]]

输出: 1

解释:

只有一种方式可以组成一个水平梯形。

提示:

4 <= points.length <= 10 5 ^5 5

--10 8 ^8 8 <= xi, yi <= 10 8 ^8 8

所有点两两不同。

我们可以先把每行有几个点保存到一个哈希表中,然后遍历哈希表,遍历每一行时,计算出当前行中任取两点有几种取法c,然后将c与之前遍历到的行中任取两点的取法之和相乘:

cpp 复制代码
class Solution {
public:
    int countTrapezoids(vector<vector<int>>& points) {
        unordered_map<int, int> cnt;
        for (vector<int> &point : points) {
            ++cnt[point[1]];
        }

        long long ans = 0;
        long long s = 0;
        for (pair<const int, int> oneCnt : cnt) {
            int num = oneCnt.second;
            long long c = (long long)num * (num - 1) / 2;
            
            ans += c * s;
            s += c;
        }

        return ans % (int)(1e9 + 7);
    }
};

如果points中有n个点,点所在的行的范围为m,则此算法时间复杂度为O(n),空间复杂度为O(m)。

相关推荐
yyy(十一月限定版)22 分钟前
数电1对应latex代码
算法
jieyucx22 分钟前
Go语言切片:动态灵活的数据序列
算法·golang·指针·顺序表·数组·结构体·切片
我头发多我先学23 分钟前
C++ 红黑树:从规则到实现,手把手带你写一棵红黑树
数据结构·c++·算法
nlpming36 分钟前
opencode SQLite 数据库结构与查询手册
算法
Cando学算法40 分钟前
中位数定理:到所有点的距离之和最小的点就是中位数
c++·算法·学习方法
nlpming41 分钟前
opencode 上下文压缩(Compaction)机制
算法
anew___44 分钟前
算法刷题避坑指南:从数据规模到易错点的实战总结
算法
HZY1618yzh1 小时前
洛谷题解:P16304 [蓝桥杯 2026 省 Java C 组] 抽奖活动
java·c++·算法·蓝桥杯
智者知已应修善业1 小时前
【51单片机从奇数始再转偶数逐一点亮并循环】2023-9-8
c++·经验分享·笔记·算法·51单片机
倔强的猴子(翻版)1 小时前
我用 Python 写了个排序库,一亿数据量下比 C 级 np.sort() 快 7 倍
人工智能·python·算法·阿里云·文心一言