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;
    }
};
相关推荐
智者知已应修善业12 分钟前
【不用第三变量交换2个数】2024-10-18
c语言·数据结构·c++·经验分享·笔记·算法
会编程的土豆20 分钟前
c语言时间戳从入门到精通
linux·c语言·算法
所谓伊人,在水一方33320 分钟前
【机器学习精通】第2章 | 优化算法深度解析:从梯度下降到自适应优化器
人工智能·python·算法·机器学习·信息可视化
Storynone24 分钟前
【Day24】LeetCode:122. 买卖股票的最佳时机 II,55. 跳跃游戏,45. 跳跃游戏II,1005. K次取反后最大化的数组和
python·算法·leetcode
滴滴答滴答答26 分钟前
机考刷题之 17&18&19&20&21&22 LeetCode 1248&121&43&93&62&63
算法·leetcode·职场和发展
for_ever_love__30 分钟前
Objective-C学习 类别和扩展
学习·算法·objective-c
Sakinol#31 分钟前
Leetcode Hot 100 ——回溯part02
算法·leetcode
ArturiaZ33 分钟前
【day53】
开发语言·c++·算法
历程里程碑33 分钟前
36 Linux线程池实战:日志与策略模式解析
开发语言·数据结构·数据库·c++·算法·leetcode·哈希算法
可编程芯片开发38 分钟前
基于自适应MUSIC算法的波束形成matlab仿真
算法·matlab·波束形成·自适应music