447. 回旋镖的数量

578 篇文章 ¥299.90 ¥399.90
570 篇文章 ¥299.90 ¥399.90
给定n个互不相同的点,返回这些点构成的回旋镖总数。回旋镖由三个点(i, j, k)组成,要求i到j和i到k的距离相等。例如,当points为[[0,0],[1,0],[2,0]]时,存在两个回旋镖。问题要求1 <= n <= 500,且所有点坐标在[-104, 104]范围内,且各不相同。" 132126761,7337247,Rust编程实践:安全高效构建系统软件,"['开发语言', '架构设计', '编程实践', '系统开发', '并发编程']

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

给定平面上 n 对 互不相同 的点 points ,其中 points[i] = [xi, yi] 。回旋镖 是由点 (i, j, k) 表示的元组 ,其中 i 和 j 之间的距离和 i 和 k 之间的距离相等(需要考虑元组的顺序)。

返回平面上所有回旋镖的数量。
示例 1:

输入:points = [[0,0],[1,0],[2,0]]
输出:2
解释:两个回旋镖为 [[1,0],[0,0],[2,0]] 和 [[1,0],[2,0],[0,0]]
示例 2:

输入:points = [[1,1],[2,2],[3,3]]
输出:2
示例 3:

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

提示:

n == points.length
1 <= n <= 500
points[i].length == 2
-104 <= xi, yi <= 104
所有点都 互不相同

class Solution {
public:
    int numberOfBoomerangs(vector<vector<int>>& points) {
        int dis = 0;
        int ret = 0;
        for(int i = 0;i<points.size();i++)
        {
            unordered_map&l
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值