2584:分割数组使乘积互质(2159 分)
目录
题目
给你一个长度为 n
的整数数组 nums
,下标从 0 开始。
如果在下标 i
处 分割 数组,其中 0 <= i <= n - 2
,使前 i + 1
个元素的乘积和剩余元素的乘积互质,则认为该分割 有效 。
- 例如,如果
nums = [2, 3, 3]
,那么在下标i = 0
处的分割有效,因为2
和9
互质,而在下标i = 1
处的分割无效,因为6
和3
不互质。在下标i = 2
处的分割也无效,因为i == n - 1
。
返回可以有效分割数组的最小下标 i
,如果不存在有效分割,则返回 -1
。
当且仅当 gcd(val1, val2) == 1
成立时,val1
和 val2
这两个值才是互质的,其中 gcd(val1, val2)
表示 val1
和 val2
的最大公约数。
示例 1:
输入:nums = [4,7,8,15,3,5] 输出:2 解释:上表展示了每个下标 i 处的前 i + 1 个元素的乘积、剩余元素的乘积和它们的最大公约数的值。 唯一一个有效分割位于下标 2 。
示例 2:
输入:nums = [4,7,15,8,3,5] 输出:-1 解释:上表展示了每个下标 i 处的前 i + 1 个元素的乘积、剩余元素的乘积和它们的最大公约数的值。 不存在有效分割。
提示:
n == nums.length
1 <= n <= 104
1 <= nums[i] <= 106
相似问题:
分析
先考虑 nums[0]:
- 对于 nums[0] 的某个因数 p,如果 nums[j] 也有因数 p,那么分割点必须在 j 之后
- 找出 nums[0] 所有因数存在的最靠后的下标 r
- 假如 r==0,那么分割点即是 0
- 否则,[0,r] 必须分割到一起,要继续遍历
接着考虑 nums[1]:
- 同理,找出所有因数存在的最靠后的下标 r2,更新 r=max(r,r2)
- 如果 r==1,分割点即是 1。否则,继续遍历
因此,找出 nums 每个元素的素因数,并得到每个素因数存在的最靠后的下标,即可遍历解决。
解答
|
|
936 ms
*附加
还可以借助埃氏筛法先获得数据范围内的质数列表,加快元素的质因数分解。
|
|
396 ms