算法|每日一题|同积元组|哈希统计

1726.同积元组

原题地址: 力扣每日一题:同积元组

给你一个由 不同 正整数组成的数组 nums ,请你返回满足 a * b = c * d 的元组 (a, b, c, d) 的数量。其中 a、b、c 和 d 都是 nums 中的元素,且 a != b != c != d 。

java 复制代码
class Solution {
    public int tupleSameProduct(int[] nums) {
        int n = nums.length;
        Map<Integer, Integer> cnt = new HashMap<>();
        for (int i = 0; i < n; i++) {
            for (int j = i + 1; j < n; j++) {
            	// 存储两个数的积
                int key = nums[i] * nums[j];
                // 如果有该乘积了就加1,如果没有就赋值1
                cnt.put(key, cnt.getOrDefault(key, 0) + 1);
            }
        }
        int ans = 0;
        for (Integer v : cnt.values()) {
        	// v是每个乘积的次数,超过1次说明有符合题目条件的元组
        	// 对于得到相同乘积的不同个元组(a,b),总共能再组合v*(v-1)/2次
        	// 每种包含四个元素的组合有八种排列方式
            ans += v * (v - 1) * 4;
        }
        return ans;
    }
}

如果对您有帮助,请点赞关注支持我,谢谢!❤

如有错误或者不足之处,敬请指正!❤

相关推荐
重生之后端学习1 分钟前
62. 不同路径
开发语言·数据结构·算法·leetcode·职场和发展·深度优先
小资同学3 分钟前
考研机试 -Kruskal算法
算法
冬夜戏雪4 分钟前
实习面经摘录(六)
java
big_rabbit05026 分钟前
[算法][力扣283]Move Zeros
算法·leetcode·职场和发展
把你毕设抢过来7 分钟前
基于Spring Boot的演唱会购票系统的设计与实现(源码+文档)
java·spring boot·后端
⑩-7 分钟前
Redis内存淘汰策略?如何处理大Key?
java·数据库·redis
小资同学9 分钟前
考研机试动态规划 线性DP
算法·动态规划
淡泊if10 分钟前
eBPF 实战:一次诡异的 Nginx 高延迟,我用 5 分钟在内核里找到了真凶
java·运维·nginx·微服务·ebpf
listhi52014 分钟前
两台三相逆变器并联功率分配控制MATLAB实现
算法
Evand J17 分钟前
【IMM】非线性目标跟踪算法与MATLAB实现:基于粒子滤波的交互式多模型,结合CV和CT双模型对三维空间中的机动目标进行高精度跟踪
算法·matlab·目标跟踪·pf·粒子滤波·imm·多模型