其他分享
首页 > 其他分享> > 【题解】CF1408I Bitwise Magic

【题解】CF1408I Bitwise Magic

作者:互联网

求最后修正的异或和就行,考虑每个位置最后被操作的次数:

\[F(x,y)=\prod_{i=1}^{n}\left(\sum_{j=0}^{k}\frac{x^j}{j!}y^{a_i\oplus (a_{i}-j)}\right) \]

这里从 \(a_i\oplus (a_i-j)\) 考虑。具体地考虑 \(\left\{x\oplus (x-1),x\oplus (x-2),\cdots, x\oplus (x-k)\right\}\) 的数量,记 \(t\) 为最低位。

那么个数就是 \(O(ck)\) 的,\(n\) 个 \(a_i\) 都可以对应到其中的一个去。接着就需要求出 \(G_i(x,y)\) 表示第 \(i\) 个方案的多项式,\(a_{i,j}\) 表示第 \(i\) 个方案的第 \(j\) 个值,\(r_i\) 表示第 \(i\) 个方案的出现次数。考虑将 \(G_i(x,y)\) 求 \(\ln\) 加和后求 \(\exp\) 。

\[G_i(x,y)=\sum_{j=0}^{k}\frac{x^j}{j!}y^{a_{i,j}} \]

再继续讨论 \(G_i(x,y)\) 怎么做之前,先来讨论一下怎么做 \(\ln\)(边界为 \(B_0=0\)):

\[B(x)=\ln A(x)\Rightarrow B'(x)A(x)=A'(x)\\ B_{n}=\frac{A_{n}}{A_{0}}-\frac{1}{nA_{0}}\sum_{i=1}^{n-1}iB_{i}A_{n-i} \]

后面是异或卷积,考虑先将 \(G_i(x,y)\) 给 FWT,这样的话枚举 \(y^t\),然后做 \(\ln\) 就行。做完后再 IFWT 回来,就得到了我们想要的结果,也就是 \(\ln G_i(x,y)\) 。

最后的 \(\exp\) 也同理(边界为 \(B_0=1\)):

\[B(x)=\exp A(x)\Rightarrow B'(x)=B(x)A'(x)\\ B_{n}=\frac{1}{n}\sum_{i=0}^{n-1}B_i(n-i)A_{n-i} \]

后面的是异或卷积,做法和上面的一样。那么现在需要对 \(O(ck)\) 个方案做 \(k\) 次 FWT,复杂度是 \(O(c^2k^22^c+ck^4)\) 的,不太能通过。

考虑到不同的 \(A\) 只有 \(2^k\) 种,只需要对每种求 \(\ln\) 就行。此时复杂度为 \(O(ck^k2^c+k^22^k)\),可以通过。

代码:Submission #130984817 - Codeforces

标签:ck,Magic,ln,题解,sum,Bitwise,异或,frac,oplus
来源: https://www.cnblogs.com/qiulyqwq/p/15374427.html