Python程序:查找平方数等于两个数乘积的方式数量
假设我们有两个数组 nums1 和 nums2,我们需要找到形成的三元组(类型 1 和类型 2)的数量,遵循以下两个规则:
- 三元组 (i, j, k) 如果 nums1[i]^2 = nums2[j] * nums2[k],其中 [0 <= i < nums1 的大小 且 0 <= j < k < nums2 的大小]。
- 三元组 (i, j, k) 如果 nums2[i]^2 = nums1[j] * nums1[k],其中 [0 <= i < nums2 的大小 且 0 <= j < k < nums1 的大小]。
因此,如果输入类似于 nums1 = [7,4] nums2 = [5,2,8,9],则输出将为 1,因为存在一个类型 1 的三元组,(1,1,2),nums1[1]^2 = nums2[1] * nums2[2] = (16 = 2*8)。
为了解决这个问题,我们将遵循以下步骤
- cnt1 := 一个映射,用于保存 nums1 中每个元素及其计数
- cnt2 := 一个映射,用于保存 nums2 中每个元素及其计数
- 定义一个函数 triplets()。它将接收 arr1 和 arr2 作为参数
- ans := 0
- 对于 arr1 的每个元素 t 及其值 v,执行以下操作:
- k := 如果 arr2 中存在 t,则为 arr2[t],否则为 0
- tmp := k*(k - 1) / 2
- sq := t * t
- 对于 arr2 中的每个元素 m,执行以下操作:
- 如果 m < t 且 sq 除以 m 的余数为 0,则
- tmp := tmp + (如果 arr2 中存在 m,则为 arr2[m],否则为 0) * (如果 arr2 中存在 sq/m 的商,则为 arr2[sq/m 的商],否则为 0)
- 如果 m < t 且 sq 除以 m 的余数为 0,则
- ans := ans + tmp * v
- 返回 ans
- 从主方法中,执行以下操作:
- 返回 triplets(cnt1, cnt2) + triplets(cnt2, cnt1)
示例
让我们看看以下实现以更好地理解:
from collections import Counter def solve(nums1, nums2): cnt1 = Counter(nums1) cnt2 = Counter(nums2) def triplets(arr1, arr2): ans = 0 for t, v in arr1.items(): k = arr2.get(t, 0) tmp = k * (k - 1) // 2 sq = t * t for m in arr2: if m < t and sq % m == 0: tmp += arr2.get(m, 0) * arr2.get(sq // m, 0) ans += tmp * v return ans return triplets(cnt1, cnt2) + triplets(cnt2, cnt1) nums1 = [7,4] nums2 = [5,2,8,9] print(solve(nums1, nums2))
输入
[7,4],[5,2,8,9]
输出
2
广告