3336. 最大公约数相等的子序列数量
题目地址(3336. 最大公约数相等的子序列数量 - 力扣(LeetCode))
https://leetcode.cn/problems/find-the-number-of-subsequences-with-equal-gcd/
题目描述
前置知识
动态规划
公司
暂无
思路
像这种需要我们划分为若干个集合(通常是两个,这道题就是两个)的题目,通常考虑枚举放入若干个集合中的元素分别是什么,考虑一个一个放,对于每一个元素,我们枚举放入到哪一个集合(根据题目也可以不放入任何一个集合,比如这道题)。
注意这里说的是集合,如果不是集合(顺序是有影响的),那么这种方法就不可行了
当然也可以枚举集合,然后考虑放入哪些元素,不过由于一般集合个数远小于元素,因此这种方式没有什么优势,一般不使用。
对于这道题来说,对于 nums[i],我们可以:
放入 seq1
放入 seq2
不放入任何序列
三种情况。当数组中的元素全部都经过上面的三选一操作完后,seq1 和 seq2 的最大公约数相同,则累加 1 到答案上。
定义状态 dp[i][gcd1][gcd2] 表示从 i 开始,seq1 的最大公约数是 gcd1,seq2 的最大公约数是 gcd2, 划分完后 seq1 和 seq2 的最大公约数相同的划分方法有多少种。答案就是 dp(0, -1, -1)。初始值就是 dp[n][x][x] = 1 其中 x 的范围是 [1, m] 其中 m 为值域。
关键点
nums[i] 放入哪个集合
代码
语言支持:Python3
Python3 Code:
复杂度分析
令 n 为数组长度, m 为数组值域。
动态规划的复杂度就是状态个数乘以状态转移的复杂度。状态个数是 n*m^2,而转移复杂度是 O(1)
时间复杂度:$O(n*m^2)$
空间复杂度:$O(n*m^2)$
此题解由 力扣刷题插件 自动生成。
力扣的小伙伴可以关注我,这样就会第一时间收到我的动态啦~
以上就是本文的全部内容了。大家对此有何看法,欢迎给我留言,我有时间都会一一查看回答。更多算法套路可以访问我的 LeetCode 题解仓库:https://github.com/azl397985856/leetcode 。 目前已经 54K star 啦。大家也可以关注我的公众号《力扣加加》带你啃下算法这块硬骨头。
关注公众号力扣加加,努力用清晰直白的语言还原解题思路,并且有大量图解,手把手教你识别套路,高效刷题。
最后更新于