LeetCode 447.回旋镖的数量

给定平面上 n 对 互不相同 的点 points ,其中 pointsi = 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

pointsi.length == 2

-104^44 <= xi, yi <= 104^44

所有点都 互不相同

遍历回旋镖的中点,然后看有多少个点到中点的距离相等:

cpp 复制代码
class Solution {
public:
    int numberOfBoomerangs(vector<vector<int>>& points) {
        unordered_map<int, int> cnt;

        int ans = 0;
        for (vector<int> &pointi : points) {
            cnt.clear();
            for (vector<int> &pointjk : points) {
                int distance = (pointi[0] - pointjk[0]) * (pointi[0] - pointjk[0]) + 
                               (pointi[1] - pointjk[1]) * (pointi[1] - pointjk[1]);
                if (cnt.find(distance) != cnt.end()) {
                    ans += cnt[distance];
                }

                ++cnt[distance];
            }
        }

        return ans * 2;
    }
};

如果有n个点,则此算法时间复杂度为O(n2^22),空间复杂度为O(n)。

相关推荐
ZPC82102 分钟前
如何将机械臂末端定位精度提升至微米如何进行标定
人工智能·算法·机器人
wabs6664 分钟前
关于动态规划【力扣343.整数拆分的递推公式怎么理解?】
算法·leetcode·动态规划
测试狗科研平台5 分钟前
第一性原理CO2还原反应计算流程和软件推荐
科技·算法·云计算
SEO_juper5 分钟前
2026 谷歌 SEO&GEO 常见问题合集:收录、排名、内容、技术全解析
算法·谷歌·常见问题·seo·跨境电商·外贸·geo
叫我:松哥17 分钟前
基于卷积神经网络的静态手势语识别算法,在测试集上的识别准确率达到97.5%
人工智能·python·深度学习·神经网络·算法·cnn
珊瑚里的鱼20 分钟前
【动态规划】买卖股票的最佳时机含手续费
算法·动态规划
2401_8856651942 分钟前
从零搭建卷积神经网络:基于PyTorch实现MNIST手写数字分类
pytorch·python·神经网络·算法·机器学习·分类·cnn
bIo7lyA8v42 分钟前
算法优化的多层缓存映射与访问调度模型的技术8
算法
dongf20191 小时前
R语言朴素贝叶斯算法---iris数据集
开发语言·算法·数据分析·r语言
小O的算法实验室1 小时前
2025年KBS,基于强化学习离散状态转移算法+复杂约束下多无人机任务分配
算法