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;
    }
};
相关推荐
( •̀∀•́ )9201 小时前
高性能拖拽排序
java·开发语言·算法
Ayanami_Reii1 小时前
进阶数据结构应用-区间最大公约数
开发语言·数据结构·算法·线段树·差分·树状数组·fenwick tree
在人间负债1 小时前
昇腾 RAG SDK 从入门到实战:技术解析与部署实操
后端·算法
大千AI助手1 小时前
多维空间的高效导航者:KD树算法深度解析
数据结构·人工智能·算法·机器学习·大千ai助手·kd tree·kd树
凋零蓝玫瑰2 小时前
几何:数学世界的空间密码
人工智能·算法·机器学习
LDG_AGI2 小时前
【推荐系统】深度学习训练框架(九):推荐系统与LLM在Dataset、Tokenizer阶段的异同
人工智能·深度学习·算法·机器学习·推荐算法
爪哇部落算法小助手2 小时前
每日两题day61
数据结构·c++·算法
Swift社区2 小时前
LeetCode 439 - 三元表达式解析器
算法·leetcode·ssh
小殊小殊2 小时前
重磅!DeepSeek发布V3.2系列模型!
论文阅读·人工智能·算法