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

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;
    }
}

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

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

相关推荐
有梦想的攻城狮几秒前
Maven中的settings.xml文件配置详解
xml·java·maven·settings.xml
wearegogog12312 分钟前
液压位置控制源代码实现与解析(C语言+MATLAB联合方案)
java·c语言·matlab
CoovallyAIHub15 分钟前
2025 年度 AI 行业百科《State of AI 2025》来了!推理元年、算力焦虑与价值回归
深度学习·算法·计算机视觉
游坦之28 分钟前
基于Java Swing的智能数据结构可视化系统 | 支持自然语言交互的AI算法助手
java·数据结构·交互
王嘉俊92532 分钟前
设计模式--装饰器模式:动态扩展对象功能的优雅设计
java·设计模式·装饰器模式
寒冬没有雪34 分钟前
矩阵的翻转与旋转
c++·算法·矩阵
ʚ希希ɞ ྀ35 分钟前
二叉树的层序遍历
数据结构·算法
m0_7431064636 分钟前
【VGGT-X】:尝试将VGGT用到3DGS重建中去
人工智能·算法·计算机视觉·3d·几何学
十二imin41 分钟前
霍夫丁不等式详解
算法·机器学习·概率论
循着风1 小时前
多种二分查找
java