447. Number of Boomerangs

题目:

Given n points in the plane that are all pairwise distinct, a "boomerang" is a tuple of points (i, j, k) such that the distance between iand j equals the distance between i and k (the order of the tuple matters).

Find the number of boomerangs. You may assume that n will be at most 500 and coordinates of points are all in the range [-10000, 10000](inclusive).

Example:

Input:
[[0,0],[1,0],[2,0]]Output:
2Explanation:
The two boomerangs are [[1,0],[0,0],[2,0]] and [[1,0],[2,0],[0,0]]

链接:https://leetcode.com/problems/number-of-boomerangs/#/description

3/25/2017

自己的算法超时了,看别人答案

然而,基本上除了计算距离之外,不需要记录很多,因为本身答案需要的也就是数量而不是index

有时候需要想一想有没有简单的方法,想不到再硬来。

https://discuss.leetcode.com/topic/66587/clean-java-solution-o-n-2-166ms/2

回忆着这个答案,还是错了,真正理解了一下:

注意加count和map.clear()是在每个i里都进行的。为什么?当有从一个顶点开始相同的距离时,这个顶点就是i为index的点。而另外一个点就是相同距离里的其他点,用排列数计算。

 1 public int numberOfBoomerangs(int[][] points) {
 2     int res = 0;
 3 
 4     Map<Integer, Integer> map = new HashMap<>();
 5     for(int i=0; i<points.length; i++) {
 6         for(int j=0; j<points.length; j++) {
 7             if(i == j)
 8                 continue;
 9             
10             int d = getDistance(points[i], points[j]);                
11             map.put(d, map.getOrDefault(d, 0) + 1);
12         }
13         
14         for(int val : map.values()) {
15             res += val * (val-1);
16         }            
17         map.clear();
18     }
19     
20     return res;
21 }
22 
23 private int getDistance(int[] a, int[] b) {
24     int dx = a[0] - b[0];
25     int dy = a[1] - b[1];
26     
27     return dx*dx + dy*dy;
28 }

更多讨论:

https://discuss.leetcode.com/category/574/number-of-boomerangs

转载于:https://www.cnblogs.com/panini/p/6621957.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/488788.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

jquery获取html页面参数乱码,JS或Jquery获取浏览器URL的参数值 汉字值乱码 并转码...

1、获取url很简单&#xff0c;代码如下&#xff1a;window.location.href;2、jquery获取url参数比较复杂&#xff0c;要用到正则表达式&#xff0c;所以学好javascript正则式多么重要的事情首先看看单纯的通过javascript是如何来获取url中的某个参数&#xff1a;//获取url中的参…

信阳农林技术学院经纬度_信阳无人机创业团队:让梦想在田野起飞

青春由磨砺而出彩&#xff0c;人生因奋斗而升华。在河南信阳&#xff0c;有这样一个年轻的创业团队&#xff0c;他们立志扎根农村做新型农民。他们在大学期间就钻研如何把无人机技术和现代农业生产相结合&#xff0c;并且运用到田间地头&#xff0c;在田野之上放飞青春梦想。一…

edge怎么开启沉浸式阅读_建安中艺光影秀|景区乐园开启沉浸式光影秀互动之旅...

随着时代的发展&#xff0c;文旅夜游的主旋律逐渐向声、光、电的科技和水、陆、空的视听体验靠近&#xff0c;越来越多的园林景点打造沉浸式光影互动投影秀&#xff0c;将历史人文与自然界的静谧纯粹相结合&#xff0c;利用沉浸式光影秀将园林景区中假山、悬崖、溶洞、峭壁、飞…

李德毅院士:自动驾驶与智能网联

来源&#xff1a;58车在电动化、智能化、网联化革命带动下&#xff0c;传统的汽车产业供应链正在重塑&#xff0c;中国电动汽车发展进入结构调整期。以“把握形势 聚焦转型 引领创新”为主题的2020中国电动汽车百人会论坛于1月10-12日在钓鱼台国宾馆隆重召开。秉持“传递权威信…

有用的Python模块 - pprint

当想在终端打印一个很大的字典或者一个很长的列表时&#xff0c;总是被print打印出来的效果气懵在电脑前&#xff0c;现在有pprint就不用担心啦。 最直接的使用方式就是 import pprint pprint.pprint(object) ex: import pprintd {user: icebug,gender: male }pprint.pprint(d…

android录音播放列表,android数据库里的视频,图片,音频表

数据库模式分析图片数据库图片数据库由两个表组成&#xff0c;分别是 images 和 thumbnails&#xff0c;物理数据模型如下所示(Power Designer 逆向工程生成)Note: 如何数据库物理模型图&#xff1a; 表示此为主键。其余的表名、字段名、数据类型应该都能看明白。Note: SQLite …

科技领域看不见的手如何影响企业未来命运

作者&#xff1a;刘锋“看不见的手”像幽灵一样盘踞在人类社会的发展过程中&#xff0c;时隐时现&#xff0c;在亚当斯密的《国富论》中&#xff0c;看不见的手推动了经济的发展&#xff1b;在达尔文的进化论中&#xff0c;看不见的手推动了生物的自然选择&#xff1b;同样在21…

电脑动态屏保_Mac待机也能看时间,你需要一款时钟屏保!

Mac待机也能看时间啦&#xff0c;时钟屏保软件就可以做到哦&#xff0c;今天就为大家分享几款&#xff0c;来看看有没有喜欢的&#xff01;Mac待机时也能看时间&#xff08;原文&#xff09;​www.macz.com第一款&#xff1a;Word Clock 一起进入Word时钟的词云。 Word Clock M…

怎样用python搭建简单的系统_如何用Python搭建一个简单的推荐系统?

本文使用的数据集是MovieLens数据集&#xff0c;该数据集由明尼苏达大学的Grouplens研究小组整理。它包含1,10和2亿个评级。 Movielens还有一个网站&#xff0c;我们可以注册&#xff0c;撰写评论并获得电影推荐。接下来我们就开始实战演练。在这篇文章中&#xff0c;我们会使用…

垂直居中——登录界面

弹性盒子垂直居中&#xff1a;body直接display&#xff1a;flex不行中间在来一层。 1 <!DOCTYPE html>2 <html>3 <head>4 <meta charset"utf-8">5 <link rel"stylesheet" href"https://cdn.static.runoob.com/libs/bootst…

LeetCode 2942. 查找包含给定字符的单词

给你一个下标从 0 开始的字符串数组 words 和一个字符 x 。 请你返回一个 下标数组 &#xff0c;表示下标在数组中对应的单词包含字符 x 。 注意 &#xff0c;返回的数组可以是 任意 顺序。 示例 1&#xff1a; 输入&#xff1a;words [“leet”,“code”], x “e” 输出…

html的组织顺序是什么,css如何组织?

css如何组织&#xff1f;下面本篇文章给大家介绍一下。有一定的参考价值&#xff0c;有需要的朋友可以参考一下&#xff0c;希望对大家有所帮助。前端工程师在开发一个单页面或者小网站的时候有可能不会在意CSS的组织问题&#xff0c;但如果要开发一个中大型的网站&#xff0c;…

oracle IF_Oracle和MySQL的区别(持续更新)

近期工作中有接触Oracle&#xff0c;发现和MySQL还是有一些语法使用上的差别&#xff0c;将常用的、遇到的总结如下~~~1.oracle只能用单引号&#xff0c;mysql单引号&#xff0c;双引号都可以&#xff1b;2.oracle的group by中不能使用别名&#xff0c;mysql可以&#xff1b;3.…

北航、旷视联合,打造最强实时语义分割网络

来源&#xff1a;AI科技评论编辑&#xff1a;Camel导语&#xff1a;MSFNet在Cityscapes测试集上达到77.1%mIoU/41FPS&#xff08;注意是1024*2048&#xff09;&#xff0c;在Camvid测试集上达到75.4 mIoU/97FPS&#xff0c;是目前最强的实时语义分割网络。下面要介绍的论文由北…

oracle text类型_数据库的一些注入技巧Oracle

默认数据库SYSTEMSYSAUX注释--SELECT * FROM Users WHERE username OR11 -- AND password ;查询版本信息SELECT banner FROM v$version WHERE banner LIKE Oracle%;SELECT banner FROM v$version WHERE banner LIKE TNS%;SELECT version FROM v$instance;数据库凭证SELECT u…

Java 装箱和拆箱

转载于:https://www.cnblogs.com/jiangxifanzhouyudu/p/6629165.html

批量修改计算机用户名,域环境下批量修改计算机名

C:\Users\Administrator>netdomrenamecomputernn/newname:N143/userd:rw\administrator/passwordd:1qazWSX/usero:administrator/passwordo:1qazWSX/reboot:3格式&#xff1a;netdomrenamecomputer计算机名/newname:新计算机名/userd:域\用户名/passwordd:password|*/usero:…

中科院计算所关于“木兰”语言问题处理情况说明

来源&#xff1a;中国科学院计算技术研究所 近日&#xff0c;网上出现质疑“木兰”语言的信息。我所获知这一情况后高度重视。经所科研道德委员会初步调查&#xff0c;“木兰”语言系我所员工刘雷创办的中科智芯公司研发的面向青少年编程教育的集成化产品&#xff0c;该产品的开…

用python表白代码_如何用Python代码向心爱的姑娘花式表白?

刚好之前用turtle 写过一个https://www.zhihu.com/video/1058809172984004608 这是我当时自学python第二天写的一个&#xff0c;书上讲到了一个turtle模块&#xff0c;可以用来画一些简单的图&#xff0c;自己突发奇想就在纸上大概设计了一下图形&#xff0c;算了算长度后&…

ipv6抓包 tcpdump_网络抓包工具tcpdump图文教程

tcpdump工具可以将网络中传送的数据包完全截获下来提供分析。还支持网络层、协议、主机或端口的过滤&#xff0c;并提供and/or/not等逻辑语句来去掉无用的信息。通过本文可以熟悉TcpDump工具&#xff0c;对网络数据抓包不再难!1、首先是在Linux系统上安装tcpdump&#xff0c;通…