【每日一题】同积元组

文章目录

Tag

【哈希表+组合】【数组】【2023-10-19】


题目来源

1726. 同积元组


题目解读

在一个由不同正整数组成的数组中找出满足 a * b = c * d 的四元组 (a, b, c, d),返回这样的四元组的数量。


解题思路

方法一:哈希表+组合

我可以先统计所有不同的乘积的数量,如果某一种乘积的数量 m 大于 1,那么可以从中拿出两个乘积(对应 4 个不同的数字)进行组合,每一种四元组内数字交换顺序后可以有 8 种四元组。那么,此时符合条件的四元组有:

C m 2 × 8 种 C_{m}^{2}\times 8种 Cm2×8种

最后,返回累加和即可。

实现代码

cpp 复制代码
class Solution {
public:
    int tupleSameProduct(vector<int>& nums) {
        unordered_map<int, int> cnts;
        int n = nums.size();
        for (int i = 0; i < n; ++i) {
            for (int j = i + 1; j < n; ++j) {
                ++cnts[nums[i] * nums[j]];
            }
        }
        int res = 0;
        for (auto [_, cnt] : cnts) {
            if (cnt >= 2) {
                res += cnt * (cnt - 1) / 2 * 8;
            }
        }
        return res;
    }
};

复杂度分析

时间复杂度: O ( n 2 ) O(n^2) O(n2), n n n 为数组 nums 的长度。

空间复杂度: O ( k ) O(k) O(k), k k k 为不同的乘积数量。


其他语言

python3

python3 复制代码
class Solution:
    def tupleSameProduct(self, nums: List[int]) -> int:
        cnts = defaultdict(int)
        n = len(nums)
        for i in range(n):
            for j in range(i+1, n):
                cnts[nums[i] * nums[j]] += 1
        
        res = 0
        for _, val in cnts.items():
            if val >= 2:
                res += val * (val - 1) // 2 * 8
        return res

defaultdict 是 Python 中 collections 模块中的一个数据结构,它是 dict 的一个子类。defaultdict 的主要特点是允许你在创建字典时为所有键设置一个默认值,这意味着当你访问不存在的键时,它不会引发 KeyError,而会返回默认值。

在使用 defaultdict 之前通常需要引入库:

py 复制代码
from collections import defaultdict

代码中的 defaultdic(int) 表示创建一个 defaultdict,所有不存在的键默认值为0。


写在最后

如果文章内容有任何错误或者您对文章有任何疑问,欢迎私信博主或者在评论区指出 💬💬💬。

如果大家有更优的时间、空间复杂度方法,欢迎评论区交流。

最后,感谢您的阅读,如果感到有所收获的话可以给博主点一个 👍 哦。

相关推荐
KarrySmile5 小时前
HOT100--Day23--153. 寻找旋转排序数组中的最小值,4. 寻找两个正序数组的中位数,20. 有效的括号
二分查找·数组··hot100·二分法·二分搜索·旋转排序数组
一叶难遮天3 天前
Android面试指南(八)
java·设计模式·数组·hashmap·string·android面试·匿名内部类
ShineWinsu11 天前
对于牛客网—语言学习篇—编程初学者入门训练—复合类型:BC140 杨辉三角、BC133 回型矩阵、BC134 蛇形矩阵题目的解析
c语言·矩阵·数组·蛇形矩阵·杨辉三角·牛客网·回型矩阵
ShineWinsu14 天前
对于牛客网—语言学习篇—编程初学者入门训练—复合类型:BC136 KiKi判断上三角矩阵及BC139 矩阵交换题目的解析
c语言·c++·学习·算法·矩阵·数组·牛客网
嗑嗑嗑瓜子的猫19 天前
大白话聊一聊,数据结构的基石:数组和链表
数据结构·链表·数组
ankleless1 个月前
C语言(11)—— 数组(超绝详细总结)
c语言·零基础·数组·二维数组·自学·一维数组
梁辰兴1 个月前
数据结构:串、数组与广义表
开发语言·数据结构·c··数组·广义表
没有bug.的程序员1 个月前
《常见高频算法题 Java 解法实战精讲(1):链表与数组》
java·算法·链表·数组
意法半导体STM321 个月前
STM32CubeMX 生成时钟获取函数的分析
mcu·stm32cubemx·数组·st·意法半导体·hal 时钟获取函数
Alfred king1 个月前
Leetcode 四数之和
算法·leetcode·职场和发展·数组·排序·双指针