LeetCode——447. 回旋镖的数量

大佬,牛!!!

  • 题目:给你一个n*2的数组,表示n个点。然后让你从中选择三个点i,j,k,使得i到j和i到k的欧氏距离相等。问一共有多少种情况。需要注意的是,假设i,j,k是满足条件的,那么i,k,j其实也是满足条件的,并且这是两种情况。
  • 我的思路:我的思路就是先来两个for循环,然后确定前面两个点,然后根据几何法找第三个点。事先我已经把点都放在一个set集合了,set是string的,内容是点的坐标,然后用逗号拼接。这里说的几何法就是找已知两个点的x的差距(xGap)和y的差距(yGap),然后让i点的x加减xGap和Ygap、i点的y加减xGap和Ygap,最后组合一下。注意重叠的情况就好了,但是目前测下来不太对。
  • 大佬的思路:大佬的思路就是for循环点,然后构建点i到其他点的map集合,key表示距离,value表示数量。然后遍历map,如果map的value是m,则其实有A(m,2)=m*(m-1)种情况。
  • 技巧:哈希

java代码

java 复制代码
class Solution {
    public int numberOfBoomerangs(int[][] points) {
        if (points.length < 3) {
            return 0;
        }
        int ans = 0;
        for (int[] p : points) {
            Map<Integer, Integer> cnt = new HashMap<Integer, Integer>();
            for (int[] q : points) {
                int dis = (p[0] - q[0]) * (p[0] - q[0]) + (p[1] - q[1]) * (p[1] - q[1]);
                cnt.put(dis, cnt.getOrDefault(dis, 0) + 1);
            }
            for (Map.Entry<Integer, Integer> entry : cnt.entrySet()) {
                int m = entry.getValue();
                ans += m * (m - 1);
            }
        }
        return ans;
    }
}
  • 总结:其实解题的关键在于这个map的构建,感觉这个题跟leetcode的第一题有异曲同工之妙。
相关推荐
鱼跃鹰飞7 小时前
设计模式系列:工厂模式
java·设计模式·系统架构
a努力。7 小时前
国家电网Java面试被问:混沌工程在分布式系统中的应用
java·开发语言·数据库·git·mysql·面试·职场和发展
Yvonne爱编码7 小时前
Java 四大内部类全解析:从设计本质到实战应用
java·开发语言·python
J2虾虾7 小时前
SpringBoot和mybatis Plus不兼容报错的问题
java·spring boot·mybatis
毕设源码-郭学长8 小时前
【开题答辩全过程】以 基于springboot 的豪华婚车租赁系统的设计与实现为例,包含答辩的问题和答案
java·spring boot·后端
tobias.b8 小时前
408真题解析-2010-7-数据结构-无向连通图
数据结构·算法·图论·计算机考研·408真题解析
良木生香9 小时前
【鼠鼠优选算法-双指针】003:快乐数 & 004:盛水最多的容器
算法
Cx330❀9 小时前
【优选算法必刷100题】第41-42题(模拟):Z 字形变换,外观数列
c++·算法
沃尔特。9 小时前
直流无刷电机FOC控制算法
c语言·stm32·嵌入式硬件·算法
CW32生态社区9 小时前
CW32L012的PID温度控制——算法基础
单片机·嵌入式硬件·算法·pid·cw32