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代码

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的第一题有异曲同工之妙。

相关推荐

  1. LeetCode——447. 回旋数量

    2024-01-09 12:08:02       35 阅读
  2. LeetCode 447. 回旋数量,枚举+哈哈希

    2024-01-09 12:08:02       44 阅读
  3. LeetCode 0447.回旋数量:哈希表

    2024-01-09 12:08:02       42 阅读
  4. 【力扣每日一题】力扣447回旋数量

    2024-01-09 12:08:02       37 阅读
  5. 算法每日一题:回旋数量 | 坐标距离 | 哈希

    2024-01-09 12:08:02       35 阅读
  6. 2024.1.8力扣每日一题——回旋数量

    2024-01-09 12:08:02       38 阅读
  7. Leetcode 448. 找到所有数组中消失数字

    2024-01-09 12:08:02       16 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-09 12:08:02       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-09 12:08:02       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-09 12:08:02       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-09 12:08:02       18 阅读

热门阅读

  1. LeetCode 每日一题 2024/1/1-2024/1/7

    2024-01-09 12:08:02       35 阅读
  2. MySQL C API的使用

    2024-01-09 12:08:02       32 阅读
  3. 【C++之单例模式】

    2024-01-09 12:08:02       23 阅读
  4. 设计模式之单例模式

    2024-01-09 12:08:02       33 阅读
  5. XGBoost(eXtreme Gradient Boosting)

    2024-01-09 12:08:02       39 阅读
  6. 2023不懂技术的程序猿职场感悟

    2024-01-09 12:08:02       35 阅读
  7. 传说中的数据挖掘工程师,究竟是做什么的?

    2024-01-09 12:08:02       34 阅读