领扣LintCode算法问题答案-1237. 回旋镖的数量
发布日期:2021-06-30 17:10:30
浏览次数:2
分类:技术文章
本文共 1385 字,大约阅读时间需要 4 分钟。
领扣LintCode算法问题答案-1237. 回旋镖的数量
目录
1237. 回旋镖的数量
描述
在平面中给定n个点,每一对点都是不同的,“回旋镖”是一个点的的元组 (i, j, k),其中 i 和 j 之间的距离与i和k之间的距离相同 (元组的顺序是重要的) 。
找到回旋镖的数量。 您可以假设n最多为 500 并且点的坐标都在 [-10000, 10000] (包括)范围内。
样例 1:
输入:[[0,0],[1,0],[2,0]]输出:2说明:两个回旋镖是[[1,0], [0,0], [2,0]]和[[1,0], [2,0], [0,0]]
题解
public class Solution { /** * @param points: a 2D array * @return: the number of boomerangs */ public int numberOfBoomerangs(int[][] points) { // Write your code here int ret = 0; for (int i = 0; i < points.length; i++) { int[] pointA = points[i]; MappMap = new HashMap<>(); for (int j = 0; j < points.length; j++) { if (i == j) { continue; } int[] pointB = points[j]; Double dis = Math.sqrt(Math.pow(pointB[1] - pointA[1], 2) + Math.pow(pointB[0] - pointA[0], 2)); Integer count = pMap.get(dis); if (count == null) { count = 0; } pMap.put(dis, count + 1); } for (Integer count : pMap.values()) { if (count >= 2) { ret += count * (count - 1); } } } return ret; }}
鸣谢
非常感谢你愿意花时间阅读本文章,本人水平有限,如果有什么说的不对的地方,请指正。
欢迎各位留言讨论,希望小伙伴们都能每天进步一点点。
转载地址:https://le-yi.blog.csdn.net/article/details/108907438 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
能坚持,总会有不一样的收获!
[***.219.124.196]2024年04月08日 06时47分43秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
凸优化 convex optimization
2019-04-30
数据库索引 & 为什么要对数据库建立索引 / 数据库建立索引为什么会加快查询速度
2019-04-30
IEEE与APA引用格式
2019-04-30
research gap
2019-04-30
pytorch训练cifar10数据集查看各个种类图片的准确率
2019-04-30
Python鼠标点击图片,获取点击点的像素坐标
2019-04-30
路径规划(一) —— 环境描述(Grid Map & Feature Map) & 全局路径规划(最优路径规划(Dijkstra&A*star) & 概率路径规划(PRM&RRT))
2019-04-30
RRT算法(快速拓展随机树)的Python实现
2019-04-30
D*算法
2019-04-30
强化学习(四) —— Actor-Critic演员评论家 & code
2019-04-30
RESTful API
2019-04-30
优化算法(四)——粒子群优化算法(PSO)
2019-04-30
数据在Oracle中的存储
2019-04-30
轨迹规划 trajectory planning
2019-04-30
AGV自动导引运输车
2019-04-30