要求

  • 给出平面上n个点,寻找存在多少点构成的三元组(i j k),使得 i j 两点的距离等于 i k 两点的距离
  • n 最多为500,所有点坐标范围在[-10000, 10000]之间

示例

  • [[0,0],[1,0],[2,0]]
  • 2

思路

  • 对于每个点i,遍历其余点到i的距离(时间n2,空间n)
  • 查找表记录其他点到 i 的<距离,频次>
  • 对于每个距离,满足条件的三元组个数为:频次 x (频次-1)
  • 求距离时用平方,防止浮点数误差
  • 最长距离,2000^2+2000^2,32位整型不越界

实现

  • 用pair存储点坐标
 1 #include <iostream>
2 #include <vector>
3 #include <unordered_map>
4 #include <cassert>
5 #include <stdexcept>
6 #include <typeinfo>
7
8 using namespace std;
9
10 /// Using Hash Map
11 /// Time Complexity: O(n^2)
12 /// Space Complexity: O(n)
13 class Solution {
14 public:
15 int numberOfBoomerangs(vector<pair<int, int>>& points) {
16
17 int res = 0;
18 for( int i = 0 ; i < points.size() ; i ++ ){
19
20 // record中存储 点i 到所有其他点的距离出现的频次
21 unordered_map<int, int> record;
22 for(int j = 0 ; j < points.size() ; j ++)
23 if(j != i)
24 // 计算距离时不进行开根运算, 以保证精度
25 record[dis(points[i], points[j])] += 1;
26
27 for(unordered_map<int, int>::iterator iter = record.begin() ; iter != record.end() ; iter ++)
28 res += (iter->second) * (iter->second - 1);
29 }
30 return res;
31 }
32
33 private:
34 int dis(const pair<int,int> &pa, const pair<int,int> &pb){
35 return (pa.first - pb.first) * (pa.first - pb.first) +
36 (pa.second - pb.second) * (pa.second - pb.second);
37 }
38 };
39
40
41 int main() {
42 //int a = 1;
43 vector<pair<int,int>> vec;
44 vec.push_back(make_pair(0, 0));
45 vec.push_back(make_pair(1, 0));
46 vec.push_back(make_pair(2, 0));
47
48 cout << Solution().numberOfBoomerangs(vec) << endl;
49 return 0;
50 }
  • 用vector存储点坐标
 1 #include <iostream>
2 #include <vector>
3 #include <unordered_map>
4 #include <cassert>
5 #include <stdexcept>
6 #include <typeinfo>
7
8 using namespace std;
9
10 /// Using Hash Map
11 /// Time Complexity: O(n^2)
12 /// Space Complexity: O(n)
13 class Solution {
14 public:
15 int numberOfBoomerangs(vector<vector<int>>& points) {
16
17 int res = 0;
18 for( int i = 0 ; i < points.size() ; i ++ ){
19
20 // record中存储 点i 到所有其他点的距离出现的频次
21 unordered_map<int, int> record;
22 for(int j = 0 ; j < points.size() ; j ++)
23 if(j != i)
24 // 计算距离时不进行开根运算, 以保证精度
25 record[dis(points[i], points[j])] += 1;
26
27 for(unordered_map<int, int>::iterator iter = record.begin() ; iter != record.end() ; iter ++)
28 res += (iter->second) * (iter->second - 1);
29 }
30 return res;
31 }
32
33 private:
34 int dis(const vector<int> &pa, const vector<int> &pb){
35 return (pa[0] - pb[0]) * (pa[0] - pb[0]) +
36 (pa[1] - pb[1]) * (pa[1] - pb[1]);
37 }
38 };
39
40 int main() {
41 vector<vector<int>> vec;
42 vector<int> vn;
43
44 vn.push_back(0);
45 vn.push_back(0);
46 vec.push_back(vn);
47 vn.clear();
48
49 vn.push_back(1);
50 vn.push_back(0);
51 vec.push_back(vn);
52 vn.clear();
53
54 vn.push_back(2);
55 vn.push_back(0);
56 vec.push_back(vn);
57 vn.clear();
58
59 cout << Solution().numberOfBoomerangs(vec) << endl;
60 return 0;
61 }

相关

  • 149 Max Points on a Line

[刷题] 447 Number of Boomerangs的更多相关文章

  1. 447. Number of Boomerangs 回力镖数组的数量

    [抄题]: Given n points in the plane that are all pairwise distinct, a "boomerang" is a tuple ...

  2. [LeetCode]447 Number of Boomerangs

    Given n points in the plane that are all pairwise distinct, a "boomerang" is a tuple of po ...

  3. 34. leetcode 447. Number of Boomerangs

    Given n points in the plane that are all pairwise distinct, a "boomerang" is a tuple of po ...

  4. 447. Number of Boomerangs

    Given n points in the plane that are all pairwise distinct, a "boomerang" is a tuple of po ...

  5. [LeetCode&Python] Problem 447. Number of Boomerangs

    Given n points in the plane that are all pairwise distinct, a "boomerang" is a tuple of po ...

  6. LeetCode 447. Number of Boomerangs (回力标的数量)

    Given n points in the plane that are all pairwise distinct, a "boomerang" is a tuple of po ...

  7. 【LeetCode】447. Number of Boomerangs 解题报告(Java & Python)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 日期 [LeetCode] 题目地址:https:/ ...

  8. 447 Number of Boomerangs 回旋镖的数量

    给定平面上 n 对不同的点,“回旋镖” 是由点表示的元组 (i, j, k) ,其中 i 和 j 之间的距离和 i 和 k 之间的距离相等(需要考虑元组的顺序).找到所有回旋镖的数量.你可以假设 n ...

  9. 【leetcode】447. Number of Boomerangs

    题目如下: 解题思路:我首先用来时间复杂度是O(n^3)的解法,会判定为超时:后来尝试O(n^2)的解法,可以被AC.对于任意一个点,我们都可以计算出它与其余点的距离,使用一个字典保存每个距离的点的数 ...

随机推荐

  1. [Fundamental of Power Electronics]-PART I-2.稳态变换器原理分析-2.1 引言

    2.1 引言 在上一章中,介绍了降压变换器作为降低直流电压的一种方法,其仅使用非耗散开关,电感器和电容器.开关状态变换产生一个矩形波形\(v_{s}(t)\),如图2.1所示.当开关位于位置1时,该电 ...

  2. java面试-什么是GC root

    一.什么是垃圾 内存中已经不再被使用到的空间就是垃圾 二.要进行垃圾回收,如何判断一个对象是否可以被回收? 引用计数法 很难解决对象之间的循环引用问题 枚举根节点做可达性分析 通过一系列名为" ...

  3. OO第二章总结

    OO第二章总结 电梯作业终于结束了!!! 这三周作业用多线程模拟搭建电梯的运行,我从开始对多线程的一无所知到结束时的能够完成一些多线程任务的水平,进步还是蛮大的,尽管过程有点艰难. 一.复杂度与UML ...

  4. 华为分析+App Linking:一站式解决拉新、留存、促活难

    移动互联网时代,用户注意力稀缺,"如何让用户一键直达APP特定页面"越来越受到产品和运营同学的关注. 比如在各个渠道投放了APP安装广告,希望新用户下载APP首次打开时直接进入活动 ...

  5. 全网最清楚的:MySQL的insert buffer和change buffer 串讲

    目录 一.前言 二.问题引入 2.1.聚簇索引 2.2.普通索引 三.change buffer存在的意义 四.再看change buffer 五.change buffer 的限制 六.change ...

  6. Mysql 添加 create_time, update_time 创建时间 更新时间 自动更新

    # 添加 创建 更新 时间字段 ALTER TABLE `表名` ADD COLUMN `create_time`  datetime NOT NULL DEFAULT CURRENT_TIMESTA ...

  7. 黑马 - poi Excel2

    文件上传: //划线处值得效仿 构造用户列表:User.java 批量保存用户

  8. Pytorch系列:(一)常用基础操作

    各种张量初始化 创建特殊类型的tensor a = torch.FloatTensor(2,3) a = torch.DoubleTensor(2,3) ... 设置pytorch中tensor的默认 ...

  9. kubeadm安装kubernetes1.18.5

    前言 尝试安装helm3,kubernetes1.18,istio1.6是否支持现有集群平滑迁移 版本 Centos7.6 升级内核4.x kubernetes:v1.18.5 helm:v3.2.4 ...

  10. Python Basics with numpy (optional)

    Python Basics with Numpy (optional assignment) Welcome to your first assignment. This exercise gives ...