LeetCode 447.回旋镖的数量

给定平面上 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^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)。

相关推荐
Wect几秒前
LeetCode 190. 颠倒二进制位:两种解法详解
前端·算法·typescript
刘永鑫Adam5 分钟前
BiB | 蒋超实验室开发 Kun-peng(鲲鹏):实现可扩展且准确的泛域宏基因组分类
人工智能·算法·机器学习·分类·数据挖掘
ltl10 分钟前
SM3 vs SHA-256:两个哈希函数的设计哲学与性能实测
后端·算法
知星小度S15 分钟前
算法训练之递归(一)
数据结构·算法
未来之窗软件服务20 分钟前
SenseVoicecpp ggml-webgpu大模型[AI人工智能(七十五)]—东方仙盟
c++·人工智能·算法·仙盟创梦ide·东方仙盟
ZPC821033 分钟前
ROS 2 手眼标定完整方案
人工智能·算法·性能优化·机器人
Q741_1471 小时前
每日一题 力扣 3418. 机器人可以获得的最大金币数 力扣 215. 数组中的第K个最大元素 动态规划 TopK问题 C++ 题解
c++·算法·leetcode·动态规划·topk
Frostnova丶1 小时前
LeetCode 3418.机器人可以获得的最大金币数
算法·leetcode
寻寻觅觅☆1 小时前
东华OJ-基础题-31-素数(C++)
开发语言·c++·算法
仟濹1 小时前
【算法打卡day36(2026-04-02 周四)】DFS专项训练3
算法·深度优先