|
做法一:首先设 $f_i$ 表示至少 $i$ 对和睦的方案,$g_i$ 表示恰好 $i$ 对和睦的方案。 显然有: $$f_i=\sum_{j=i}^{n}{C^i_jg_j}$$ 根据二项式反演,有: $$g_i=\sum_{j=i}^{n}{(-1)^{j-i}C^i_jf_j}$$ 而我们还有: $$f_i=C^i_nA^i_n2^i(2n-2i)!$$ 于是: $$g_i=\sum_{j=i}^{n}{(-1)^{j-i}C^i_jC^j_nA^j_n2^j(2n-2j)!}$$ $$=\frac{n!^2}{i!}\sum_{j=i}^{n}{\frac{(-1)^{j-i}2^j}{(j-i)!(n-j)!}}$$ 显然可以卷积,于是时间复杂度 $O(Tn\log n)$.
本题还有个加强版,每次询问只需要求一组 $(n,k)$ 的答案,但 $T \le 2e5,n \le 5e6$。
做法二:发现实际要求的是错排的方案数,记 $F_n$ 表示 $n$ 对情侣的错排方案数,于是: $$ans(n,k)=C^k_nA^k_n2^kF_{n-k}=(C^k_n)^2k!2^kF_{n-k}$$ 而显然: $$\sum_{k=0}^{n}{ans(n,k)}=\sum_{k=0}^{n}{(C^k_n)^2k!2^kF_{n-k}}=(2n)!$$ 化成卷积形式: $$\sum_{k=0}^{n}{\frac{2^k}{k!}\frac{F_{n-k}}{(n-k)!^2}}=\frac{(2n)!}{n!^2}$$ 于是我们设: $$A(x)=\sum_{i \ge 0}{\frac{2^i}{i!}x^i}$$ 有: $$A(x)=\sum_{i \ge 0}{\frac{(2x)^i}{i!}}=e^{2x}$$ 再设: $$F(x)=\sum_{i \ge 0}{\frac{F_i}{i!^2}x^i}$$ 再设: $$B(x)=\sum_{i \ge 0}{\frac{(2i)!}{i!^2}x^i}$$ 根据广义二项式定理,有: $$B(x)=(1-4x)^{-\frac{1}{2}}$$ 再代入上边的卷积式得: $$A \cdot F=B$$ 也就是: $$F(x)=\frac{e^{-2x}}{(1-4x)^{\frac{1}{2}}}$$ 求个导: $$F'(x)=\frac{8xe^{-2x}}{(1-4x)^{\frac{3}{2}}}=\frac{8x}{1-4x}F(x)$$ 于是得到: $$F'(x)=4xF'(x)+8xF(x)$$ 观察系数: $$F_{n+1}=4n(n+1)F_n+8n^2(n+1)F_{n-1}$$ 终于得到了递推式,可以 $O(n+T)$ 解决加强版。本题同样也可 $O(n+Tn)$。
题目3353 情侣?给我烧了
![]()
2023-04-14 22:51:01
|
|
显然 $f(S)$ 即为 $m^{\mathsf{连通块个数}}$。 连通块是困难的,要搞容斥系数什么的好像也行,但这个数据范围过不去。 考虑转化一下命题,联通块内颜色相同 $\to$ 边的两点颜色相同。显然两命题等价。此时边就成了两个元素上的限制,表示一种二元关系。不妨设第 $i$ 条边表示的限制为 $p_i$。 则 $f(S)=\mathrm{sum}(\bigcap\limits_{i\in S} p_i)$,其中 $\mathrm{sum}(P)$ 表示限制集为 $P$ 的方案数。 显然只有机器人会处理交集这种限制。此时需要转换视角。发现 $(-1)^{|S|+1}$ 这个东西很像容斥系数,配上 $f(S)$ 化开后 RHS 的式子就更有容斥的感觉了。 写一下答案的式子: $$\mathrm{ans}=\sum_{\emptyset \neq S\subseteq E} (-1)^{|S|+1}\times f(S)=\sum_{\emptyset \neq S\subseteq E}(-1)^{|S|+1}\times \mathrm{sum}(\bigcap_{i\in S} p_i)=\mathrm{sum}(\bigcup_{i\in E} p_i)$$。 并集是容易处理的。正难则反一下,算总方案减去所有条件都不满足的方案,即 $m^n-m^{\underline n}$。
题目3886 完全图子图染色游戏
AAAAAAAAAA
![]()
2023-04-14 11:23:57
|
|
首先令 $a_n$ 为 $n$ 个奇点的奇树数量,类似的,定义 $b_n$ 为 $n$ 个偶点的偶树数量。 然后令 $A(x)=\sum_{i \ge 0}{a_ix^i}\ ,\ B(x)=\sum_{i \ge 0}{b_ix^i}$. 我们肯定是往根下面连若干个偶树使其成为奇树,或者是往根下面连若干个奇树使其成为偶树。 对于前者,枚举子树的大小,类似背包,可以得到: $$A(x)=x\prod_{i \ge 1}{(1+x^i+x^{2i}+\dots)^{b_i}}$$ $$=x\prod_{i \ge 1}{(\frac{1}{1-x^i})^{b_i}}$$ 乘 $x$ 是因为根本身是一个奇点。 于是: $$\ln(A(x))=\ln(x)-\sum_{i \ge 1}{b_i\ln(1-x^i)}$$ 两边求导: $$\frac{A'(x)}{A(x)}=\frac{1}{x}+\sum_{i \ge 1}{ib_i\frac{x^{i-1}}{1-x^i}}$$ 两边乘 $xA(x)$: $$xA'(x)=A(x)+A(x)\sum_{i \ge 1}{ib_i\frac{x^i}{1-x^i}}$$ 考虑第 $n$ 项系数: $$na_n=a_n+\sum_{i=1}^{n-1}{a_i\sum_{j=1}^{n-1}{jb_j([x^{n-i}]\frac{x^j}{1-x^j})}}$$ 而: $$\frac{x^j}{1-x^j}=\sum_{i \ge 1}{x^{ij}}=\sum_{i \ge 1}{[j|i]x^i}$$ 于是: $$na_n=a_n+\sum_{i=1}^{n-1}{a_i\sum_{j=1}^{n-1}{jb_j[j|n-i]}}$$ 也就是: $$a_n=\frac{\sum_{i=1}^{n-1}{a_i\sum_{j=1}^{n-1}{jb_j[j|n-i]}}}{n-1}$$
再看后者,类似的,有: $$B(x)=\prod_{i \ge 1}{(\frac{1}{1-x^i})^{a_i}}-1$$ $-1$ 是因为不存在 $0$ 个偶点的偶树。 类似得到: $$b_n=\frac{\sum_{i=0}^{n-1}{(b_i+[i=0])\sum_{j=1}^{n}{ja_j[j|n-i]}}}{n}$$
这样就可以使用分治 $NTT$ 解决了,时间复杂度 $O(n\log^2n)$.
题目3884 有根无标号「奇树」计数
![]()
2023-04-13 21:23:18
|
|
拆分成前缀和的形式,$f(x)$ 表示 $[0,x]$ 范围内的解,则答案为 $f(y)-f(x-1)$。 问题等价于将数字转化为 $b$ 进制后 $1$ 的位数为 $k$ 的方案数。 数位 DP 的思想是从高位到低位沿着 $x$ 的上界进行枚举,每次累加这一位取不到上界时的方案数,本题中,这个方案数就是组合数。 时间复杂度为 $O(log^2n)$,瓶颈在于预处理组合数。 细节有:如果 $x$ 满足条件需要在最后累加进去,且一旦有一位上的数大于 $1$ 则代表后面若干位可以任意填 $1$,这时需要跳出循环,选择了 $k$ 个 $1$ 后也应跳出循环,此时后面的若干位应全部填 $0$。
题目1621 [Ural 1057] 幂和的数量
![]()
2023-04-09 09:47:07
|
|
题目660 [ZJOI 2007] 矩阵游戏
![]()
2023-03-24 20:38:28
|
|
差分约束模板题 本题求最小值,需构造 $\ge$ 不等式组,构图求最长路,如果存在正环,则说明无解。 分析给定的 $5$ 个条件: (1) $A==B \iff A-B \ge 0\ ,\ B-A \ge 0$; (2) $A<B \iff B \ge A + 1\ ,B-A\ \ge 1$; (3) $A \ge B \iff A-B\ \ge 0$; (4) $A > B \iff A \ge B + 1\ ,A-B \ge 1$; (5) $A \le B \iff B \ge A , B-A \ge 0$; 另外还有一隐含条件: 每个小朋友都要分到糖果,因此 $x_i \ge 1$。我们可以建立一个超级源点 $x_0 = 0$,则有: $x_i\ ≥\ x_0 + 1 , x_i\ -\ x_0\ \ge 1$,即从0号点到其他所有点连边,边权为1,因为这样可确保到达任意点,到达任意边,满足所有不等式。 因为我们能求出每个 $x_i$ 的最小值,所以总体最小值就是所有的 $x_i$ 之和。
构图建边数: 如果 $K$ 取 $10^5$,假设所有的条件都是($1$),则需要 $2 \times 10^5$ 条边,从超级源点建边,需要 $10^5$ 条,因此边数预估需要 $3 \times 10^5$ 条边。 另外如果每个小朋友的糖果数是单调递增的,则结果可能爆 $int$,因此需要使用 $long\ long$ 存储结果。
题目3855 [SCOI2011] 糖果
![]()
2023-03-22 21:30:55
|