leetcode 3623

3623: 统计梯形的数目Ⅰ

思路:组合数C(n,k) (即"n 选 k")

首先,统计每一行的点的个数,如果这一行有 c 个点,那么++从这 c 个点中选 2 个点++,有c*(c-1)/2种选法,可以组成一条水平边,即梯形的顶边或底边。

枚举每一行,设这一行有 k= c*(c-1)/2 条水平边,那么另外一条边就是++之前遍历过的++行的边数 s。根据乘法原理,之前遍历过的行与这一行,一共可以组成s⋅k 个水平梯形,加入答案。

复制代码
class Solution {
public:
    int countTrapezoids(vector<vector<int>>& points) {
        constexpr int MOD=1'000'000'007;
        unordered_map<int,int> cnt;
        for(auto& p :points) cnt[p[1]]++;  // 统计每一行(水平线)有多少个点

        long long ans=0,s=0; //之前遍历过的边数 s(不同行)
        for(auto& [y,c] :cnt){  
            long long k=(long long)c*(c-1)/2;  //同一行有几条水平边
            ans+=s*k%MOD;
            s+=k;
        }

        return ans%MOD;
    }
};
相关推荐
Σίσυφος190024 分钟前
PCL法向量估计 之 RANSAC 平面估计法向量
算法·机器学习·平面
xhbaitxl29 分钟前
算法学习day39-动态规划
学习·算法·动态规划
I_LPL31 分钟前
day23 代码随想录算法训练营 回溯专题2
算法·hot100·回溯算法·求职面试
智者知已应修善业32 分钟前
【洛谷P9975奶牛被病毒传染最少数量推导,导出多样例】2025-2-26
c语言·c++·经验分享·笔记·算法·推荐算法
m0_736919101 小时前
C++中的委托构造函数
开发语言·c++·算法
小小小小王王王1 小时前
洛谷-P1886 【模板】单调队列 / 滑动窗口
c++·算法
PPPPPaPeR.1 小时前
光学算法实战:深度解析镜片厚度对前后表面折射/反射的影响(纯Python实现)
开发语言·python·数码相机·算法
看我干嘛!1 小时前
python第五次作业
算法
历程里程碑2 小时前
Linux 库
java·linux·运维·服务器·数据结构·c++·算法
Sheep Shaun2 小时前
如何让一个进程诞生、工作、终止并等待回收?——探索Linux进程控制与Shell的诞生
linux·服务器·数据结构·c++·算法·shell·进程控制