[刷题] 447 Number of Boomerangs
要求
- 给出平面上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的更多相关文章
- 447. Number of Boomerangs 回力镖数组的数量
[抄题]: Given n points in the plane that are all pairwise distinct, a "boomerang" is a tuple ...
- [LeetCode]447 Number of Boomerangs
Given n points in the plane that are all pairwise distinct, a "boomerang" is a tuple of po ...
- 34. leetcode 447. Number of Boomerangs
Given n points in the plane that are all pairwise distinct, a "boomerang" is a tuple of po ...
- 447. Number of Boomerangs
Given n points in the plane that are all pairwise distinct, a "boomerang" is a tuple of po ...
- [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 ...
- LeetCode 447. Number of Boomerangs (回力标的数量)
Given n points in the plane that are all pairwise distinct, a "boomerang" is a tuple of po ...
- 【LeetCode】447. Number of Boomerangs 解题报告(Java & Python)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 日期 [LeetCode] 题目地址:https:/ ...
- 447 Number of Boomerangs 回旋镖的数量
给定平面上 n 对不同的点,“回旋镖” 是由点表示的元组 (i, j, k) ,其中 i 和 j 之间的距离和 i 和 k 之间的距离相等(需要考虑元组的顺序).找到所有回旋镖的数量.你可以假设 n ...
- 【leetcode】447. Number of Boomerangs
题目如下: 解题思路:我首先用来时间复杂度是O(n^3)的解法,会判定为超时:后来尝试O(n^2)的解法,可以被AC.对于任意一个点,我们都可以计算出它与其余点的距离,使用一个字典保存每个距离的点的数 ...
随机推荐
- std::thread线程库详解(5)
目录 目录 前言 信号量 counting_semaphore latch与barrier latch barrier 总结 前言 前面四部分内容已经把目前常用的C++标准库中线程库的一些同步库介绍完 ...
- 面试官:聊一聊SpringBoot服务监控机制
目录 前言 SpringBoot 监控 HTTP Endpoints 监控 内置端点 health 端点 loggers 端点 metrics 端点 自定义监控端点 自定义监控端点常用注解 来,一起写 ...
- Java框架Spring Boot & 服务治理框架Dubbo & 应用容器引擎Docker 实现微服务发布
微服务系统架构实践 开发语言Java 8 框架使用Spring boot 服务治理框架Dubbo 容器部署Docker 持续集成Gitlab CI 持续部署Piplin 注册中心Zookeeper 服 ...
- 【10.5NOIP普及模拟】sum
[10.5NOIP普及模拟]sum 文章目录 [10.5NOIP普及模拟]sum 题目描述 输入 输出 输入输出样例 样例输入 样例输出 解析 code 题目描述 小x有很多糖果,分成了 N 堆,排成 ...
- Jmeter(四十二) - 从入门到精通进阶篇 - Jmeter配置文件的刨根问底 -番外篇(详解教程)
1.简介 为什么宏哥要对Jmeter的配置文件进行一下讲解了,因为有的童鞋或者小伙伴在测试中遇到一些需要修改配置文件的问题不是很清楚也不是很懂,就算修改了也是模模糊糊的.更有甚者觉得那是禁地神圣不可轻 ...
- go中控制goroutine数量
控制goroutine数量 前言 控制goroutine的数量 通过channel+sync 使用semaphore 线程池 几个开源的线程池的设计 fasthttp中的协程池实现 Start Sto ...
- 网络编程Netty入门:Netty简介及其特性
目录 Netty的简介 Netty的特性 Netty的整体结构 Netty的核心组件 Netty的线程模型 结束语 Netty的简介 Netty是一个java开源框架,是基于NIO的高性能.高可扩展性 ...
- 使用numba加速python科学计算
技术背景 python作为一门编程语言,有非常大的生态优势,但是其执行效率一直被人诟病.纯粹的python代码跑起来速度会非常的缓慢,因此很多对性能要求比较高的python库,需要用C++或者Fort ...
- mac系统 PHP Nginx环境变量修改
场景:php默认的环境变量不是我们实际工作中想要的 执行命令:which php 查看默认的php指向的目录 : /usr/bin/php 修改· ~/.bash_profile 文件 添加php环 ...
- 【Springboot】Springboot监听器Demo
/** * @author: yq * @date: 2020/8/31 0:01 * @description 自定义事件 */ @Data public class MyEvent extends ...