2024.1.8力扣每日一题——回旋镖的数量

2024.1.8

      • 题目来源
      • 我的题解
        • 方法一 双层哈希表
        • 方法二 哈希表优化版

题目来源

力扣每日一题;题序:447

我的题解

方法一 双层哈希表

构造如下的哈希表:{节点i:{距离1:数量,…距离n:数量}}
相当于求每个节点与其他 节点的欧式距离,并统计相同距离的数量,最后计算回旋镖的数量只需要看相同欧氏距离的数量超过1个的,由于可以换顺序,因此相当于在k个满足的节点之间选两个,并且有两种顺序,所以每一组的贡献为: k ( k − 1 ) 2 × 2 \frac{k(k-1)}{2}×2 2k(k1)×2

时间复杂度:O( n 2 n^2 n2)。n是节点的数量。
空间复杂度:O( n 2 n^2 n2)。

public int numberOfBoomerangs(int[][] points) {int n=points.length;Map<Integer,Map<Double,Integer>> count=new HashMap<>();for(int i=0;i<n;i++){Map<Double,Integer> t=new HashMap<>();for(int j=0;j<n;j++){if(i==j)continue;double dis=distance(points[i][0],points[i][1],points[j][0],points[j][1]);t.put(dis,t.getOrDefault(dis,0)+1);}count.put(i,t);}// System.out.println(count);int res=0;for(int key:count.keySet()){Map<Double,Integer> t=count.get(key);for(Double dis:t.keySet()){int m=t.get(dis);if(m>=2){res+=m*(m-1);}}}return res;
}   
public double distance(int x1,int y1,int x2,int y2){return Math.sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2));
}
方法二 哈希表优化版

首先外围的哈希表实际并没有什么用,我们可以在每次构建完成哈希表之后就计算以当前节点尾回旋镖中间节点的的回旋镖数量,并不需要使用两层哈希表保留结果,然后最后再同一计算。

时间复杂度:O( n 2 n^2 n2)
空间复杂度:O(n)

public int numberOfBoomerangs(int[][] points) {int n=points.length;int res=0;for(int i=0;i<n;i++){Map<Integer,Integer> t=new HashMap<>();for(int j=0;j<n;j++){if(i==j)continue;int dis=distance(points[i][0],points[i][1],points[j][0],points[j][1]);t.put(dis,t.getOrDefault(dis,0)+1);}for(Integer dis:t.keySet()){int m=t.get(dis);res+=m*(m-1);}}return res;
}   
public int distance(int x1,int y1,int x2,int y2){return (x1-x2)*(x1-x2)+(y1-y2)*(y1-y2);
}

有任何问题,欢迎评论区交流,欢迎评论区提供其它解题思路(代码),也可以点个赞支持一下作者哈😄~

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

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

相关文章

LinkedBlockingQueue原理探究

类图结构 同样首先看一下LinkedBlockingQueue的类图结构&#xff0c;以便从全局对LinkedBlockingQueue有个直观的了解。 由类图可以看到&#xff0c;LinkedBlockingQueue也是使用单向链表实现的&#xff0c;其也有两个Node,分别用来存放首、尾节点&#xff0c;并且还有一个初始…

Shell脚本入门实战:探索自动化任务与实用场景

引言 Shell脚本作为一种强大的自动化工具&#xff0c;在现代操作系统中具有广泛的应用。无论是简单的文件操作&#xff0c;还是复杂的系统管理&#xff0c;Shell脚本都能提供高效、快速的解决方案。在本文中&#xff0c;我们将探索Shell脚本的基础知识&#xff0c;并通过实战场…

x-cmd pkg | rg - 文本搜索工具,grep 命令的现代化替代品

目录 简介首次用户功能特点竞品和相关作品进一步阅读 简介 rg&#xff08;ripgrep&#xff09; 是一个逐行方式进行&#xff08; line-oriented &#xff09;的文本搜索工具&#xff0c;能够递归搜索目录中的文件内容。默认情况下&#xff0c;rg 将遵守 .gitignore 文件规则自…

偷偷读个中国社科院与新加坡新跃社科联合培养博士惊艳你们

近期&#xff0c;华尔街量化圈应届生的年薪超200万刷屏&#xff01;国内量化的人才市场又是怎样的呢&#xff1f;据记者调查&#xff0c;当前在应届生的招聘上主要以顶尖高校的博士为主&#xff0c;年薪百万起步&#xff0c;同时为实习人才提供每日1500元的实习津贴。一般情况下…

内衣洗衣机哪些品牌质量好实惠?五款好用的迷你洗衣机

随着人们的生活水平的提升&#xff0c;越来越多小伙伴来开始追求更高的生活水平&#xff0c;一些智能化的小家电就被发明出来&#xff0c;而且内衣洗衣机是其中一个。现在通过内衣裤感染到细菌真的是越来越多&#xff0c;所以我们对内衣裤的清洗频次会高于普通衣服&#xff0c;…

视频号小店和抖音小店相比,新手做哪个比较好?

我是电商珠珠 抖音小店在19年被抖音所发展&#xff0c;在这过程中&#xff0c;抖音小店通过自身的不断完善&#xff0c;从兴趣电商到全域兴趣电商模式&#xff0c;从直播电商到商城的出现&#xff0c;凭借着门槛低流量高的优势&#xff0c;让很多商家尝到了红利。 尤其是在20…

大创项目推荐 深度学习实现行人重识别 - python opencv yolo Reid

文章目录 0 前言1 课题背景2 效果展示3 行人检测4 行人重识别5 其他工具6 最后 0 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 &#x1f6a9; **基于深度学习的行人重识别算法研究与实现 ** 该项目较为新颖&#xff0c;适合作为竞赛课题方向&#xff0c…

Cookie Session和过滤器Filter

会话&#xff1a;用户打开浏览器&#xff0c;访问web服务器的资源&#xff0c;会话建立&#xff0c;直到有一方断开连接&#xff0c;会话结束。在一次会话中可以包含多次请求和响应。 会话跟踪&#xff1a;一种维护浏览器状态的方法&#xff0c;服务器需要识别多次请求是否来自…

Java程序员面试-场景篇

前言 裁员增效潮滚滚而来&#xff0c;特总结一些实际场景方案的面试题&#xff0c;希望对大家找工作有一些帮助。 注册中心 题目&#xff1a; 有三台机器&#xff0c;分别部署了微服务A、微服务B、注册中心&#xff0c;其中A和B都有服务接口提供并正常注册到了注册中心&…

HttpServletRequest setHeader

HttpServletRequest setHeader

Python——欢迎来到吱昂张游乐园

欢迎来到吱昂张游乐园&#xff01;&#xff01;&#xff01; 凡是身高小于120或者您的vip等级大于三级的皆可免费游玩。 那我们接下来就来设计一下以上的规则叭 print("欢迎来到吱昂张游乐园") if int(input("输入您的身高&#xff1a;"))>120:print…

什么是全链路压测?

随着互联网技术的发展和普及&#xff0c;越来越多的互联网公司开始重视性能压测&#xff0c;并将其纳入软件开发和测试的流程中。 阿里巴巴在2014 年双11 大促活动保障背景下提出了全链路压测技术&#xff0c;能更好的保障系统可用性和稳定性。 什么是全链路压测&#xff1f;…

中兴服务器R5300 G5算力强劲,有力支撑企业数字化转型

去年&#xff0c;可以说是AIGC大模型全面崛起的一年&#xff0c;反映出人类算力技术的突出发展成果&#xff0c;也带动全球算力规模的进一步扩大。伴随着各行各业都在投身数字化转型&#xff0c;未来人们对于算力的需求更为庞大&#xff0c;因此需要性能更优的服务器来进行支撑…

用PDETool计算磁场

学习FEM和磁场&#xff0c;Matlab中的PDETool可以直观的展示数学的结果。 在PDETool中计算磁场的步骤如下&#xff1a; 1.启动matalb&#xff0c;输入命令pdetool 2.画三个矩形 3.在工具栏的下拉列表中选Magnetostatics 4.设置区域电密 在PDE菜单中&#xff0c;选择PDEmode…

深入解读:WHERE 1=1 背后的神秘力量

一、引言 在数据库查询语言SQL中&#xff0c;WHERE子句用于过滤记录。而WHERE 11是一个常见的技巧&#xff0c;尤其在动态构建查询语句时。虽然这个条件永远为真&#xff0c;但在实际应用中&#xff0c;它却有着不可忽视的作用。本文将深入探讨WHERE 11的奥秘&#xff0c;并通…

【Flutter 开发实战】Dart 基础篇:从了解背景开始

想要学会用 Flutter 开发 App&#xff0c;就不可避免的要学习另一门很有意思的编程语言 —— Dart。很多小伙伴可能在学习 Flutter 之前可能都没听说过这门编程语言&#xff0c;我也是一样&#xff0c;还以为 Dart 是为了 Flutter 而诞生的&#xff1b;然而&#xff0c;当我们去…

目标检测数据集 - 夜间行人检测数据集下载「包含VOC、COCO、YOLO三种格式」

数据集介绍&#xff1a;夜间、低光行人检测数据集&#xff0c;真实场景高质量图片数据&#xff0c;涉及场景丰富&#xff0c;比如夜间街景行人、夜间道路行人、夜间遮挡行人、夜间严重遮挡行人数据&#xff1b;适用实际项目应用&#xff1a;公共场所监控场景下夜间行人检测项目…

Android 13 移除下拉栏中的设置入口

介绍 因为当前项目的设置已被加密&#xff0c;客户不希望通过下拉窗口的设置图标进入设置&#xff0c;决定去掉该图标。 效果展示 分析 这里首先想到在SystemUI寻找这个图标的资源文件&#xff0c;找到资源文件后寻找对应控件调用的地方&#xff0c;根据id寻找控件代码即可。…

10Bean的循环依赖+反射机制

A对象中有B属性。B对象中有A属性。这就是循环依赖。我依赖你&#xff0c;你也依赖我。 比如&#xff1a;丈夫类Husband&#xff0c;妻子类Wife。Husband中有Wife的引用。Wife中有Husband的引用。 package com.sunsplanter.spring6.bean;public class Husband {private String…

亿尚网:撤柜上线电商+直播将成为美妆行业发展的绝佳组合

亿尚网&#xff1a;撤柜上线电商直播将成为美妆行业发展的绝佳组合 来源&#xff1a; 编辑&#xff1a;亿尚风范 时间&#xff1a;2024-01-09 随着社交媒体的兴起&#xff0c;网红经济逐渐成为市场中的一股不可忽视的力量。而在这其中&#xff0c;直播电商的模式更是为网红们…