题意:
给你n
个数和一个k
. 求这n
个数的一个最小子集, 使得元素乘积为k
的倍数, 且元素之和最小.
要输出方案.
\( n \leq 10^3, k \leq 10^{12} \)
结局:
死在输出方案上了.
思路:
首先发现k
的质因数不会很多, 最多有14
个.
然后k
的因数也不会很多.
所以就dp一下. \(f_i\)表示当前积与k
的gcd为i
的时候的元素个数.
然后就像个背包一样嘛. 输出方案? 记录从哪里转移来的不就好了.
然后.
考虑这个例子.
3 9
3 24 21
你会先拿24
从3
更新到9
.
然后21
就会把3
和9
的转移都更新.
然后就炸了.
因为3
应该是从原来的状态更新的. 但是现在被覆盖了.
然后发现状态是棵树. 可以把状态可持久化记下来.
更新一个状态的时候, 不是直接覆盖, 而是新建一个状态来保证从原来的状态转移出去的情况不会出错.
这样空间复杂度应该和转移次数有关?
然后怎么就糊过去了.
另一个细节是k=1
是答案不能是0
. woc.
依然感觉很鬼蓄.