ARC180 部分简要题解

C

\(f_{i, j}\) 为考虑前 \(i\) 个数,当前选出来的子序列和为 \(j\) 且强制最后一个选出来的数不为 \(j\) 的方案;设 \(g_{i, j}\) 为考虑前 \(i\) 个数,当前选出来的子序列和为 \(j\) 且强制最后一个选出来的数必为 \(j\) 的方案。注意到一个合法方案可以唯一与一个最后一个选出来的数会变的方案对应(不断删掉最后一个选出来但没变的数,结果不变,注意这里包括全部都不选),于是有转移:

\[f_{i, j} = f_{i - 1, j}(j = a_i) \\ f_{i, j} = f_{i - 1, j} + f_{i - 1, j - a_i} + g_{i - 1, j - a_i}(j \ne a_i) \\ g_{i, j} = g_{i - 1, j}(j \ne a_i) \\ g_{i, j} = f_{i - 1, 0}(j = a_i) \]

E

非常漂亮的一道题。首先反过来考虑,求出使用不超过 \(c\) 的代价能得到的最大分数。

不妨先考虑 \(c = 0\),相当于要满足 \(n\) 条关于每个位置上逆序对的条件。考虑 \(\rm dp\),令 \(f_{i, j}\) 为近考虑排列前 \(i\) 个元素的相对顺序,以相对大小第 \(j\) 小的元素作为结尾的最长上升字序列长度,转移考虑第 \(i\) 个位置的排名,排列插入式转移。

\[f_{i, j} = \max \begin{cases} f_{i - 1, j - 1} \\ f_{i - 1, j} (i - j - 1 \ge a_i) \\ \max\limits_{k < j} f_{i - 1, k} + 1 (i - j \ge a_i) \end{cases} \]

注意到去掉 \(f_{i - 1, j}\) 对应方案的最后一个元素,一定是 \(f_{i - 1, k}(k < j)\) 的一个方案,于是转移二包含于转移三。

为了方便转移三,修改 \(\rm dp\) 定义:令 \(f_{i, j}\) 为近考虑排列前 \(i\) 个元素的相对顺序,以相对大小 不大于\(j\) 小的元素作为结尾的最长上升字序列长度。于是转移可以修改为:

\[f_{i, j} = \max(f_{i - 1, j - 1} + [i - j \ge a_i], f_{i, j - 1}) \]

为了方便令 \(j' = i - j + 1\) 于是:\(f_{i, j'} = \max(f_{i - 1, j'} + [j' \ge a_i + 1], f_{i, j' + 1})\).

由于 \(f_{i, j' + 1} \le f_{i, j'} \le f_{i, j' + 1} + 1\),于是我们可以考虑 \(f_{i, j'} = f_{i, j' + 1} + 1\) 的断点 \(j’\)。于是转移可以看作是添加断点 \(i\),然后删除 \(\le a_i\) 的最大断点。最终答案为断点的个数。

再考虑 \(c \ne 0\) 的情况,这等价于去掉任意 \(c\) 个限制(将对应 \(a_i \leftarrow 0\))之后的相同问题,于是我们来分析上述加删断点的过程。

首先,由于 \(a_i < i\),可以一开始将所有断点 \(\{1, 2, \cdots, n\}\) 添加好,然后按顺序进行删除。

按照 \(a_i\) 从大到小考虑每次删除,设最大和严格次大的 \(a_i\) 分别为 \(v_1, v_2\),所有删除 \(v_1 \le i < v_2\) 断点的行为均可提到最前完成,不影响结果。而接下来从 \(v_2\) 开始删除的断点,\(a_i = v_1\) 的那些位置就完全等同于 \(a_{i'} = v_2\) 的那些位置,递归进行上述操作。于是原本按顺序的删除转化为了上面固定的从大到小的删除,于是原问题 \(a_i\) 给出的顺序就并不重要了。

再考虑将哪些 \(a_i \leftarrow 0\) 能使断点更多:对 \(a_i > a_j\),分别考虑两种方案,一种 \(a_i \leftarrow 0\) 一种 \(a_j \leftarrow 0\);前者将 \(a_j\) 这个删除放到最后,后者将 \(a_i\) 这个删除放到最后;轮到最后一次删除时前者能删的后者一定也能删,故前者不劣。于是一定是选择最大的 \(c\)\(a_i \leftarrow 0\)

由于删除的顺序不重要,于是可以按照从小到大的顺序依次删,这样就可以求出所有去掉最大 \(c\)\(a_i\) 的结果了,这个过程可以直接线性维护。

F

原代价等价于将连乘拆开,\(\forall i\) 选一个 \(x_j ^ A(i < j \le n + 1, x_{n + 1} = 1)\) 乘起来相加。如果 \(i\) 选择了 \(x_j ^ A\),从 \(i \to j\) 连边构成一颗有根树。

原问题变成随机 \(n\)\([0, 1]\) 中的实数,排序后,对所有合法有根树求所有 \(i \to j\) 这些边 \(x_j ^ A\) 的乘积的和。不妨将顺序倒过来,先确定排序后合法的树结构,再考虑符合树结构的方案。

枚举根节点下子树的集合划分 \(S_1, S_2, \cdots, S_m\),为了使规模减小,枚举这些子树根的权值分别为 \(x_{r_1}, x_{r_2}, \cdots, x_{r_m}\)

问题转化为了限制随机上界不一定为 \(1\) 的子问题,但这样并不方便直接求。

再转化一下原问题,将权值修改为 \(\prod\limits_{i = 1} ^ n \left(y ^ A + \sum\limits_{j = i + 1} x_j ^ A\right)(x_1 \le x_2 \le \cdots \le x_n \le y)\) 这样的齐次式,接下来的计算就会方便很多。

因为原问题可以转化成钦定生成的随机数递增,根据对称性答案为:

\[\begin{aligned} a_n(y) &= n!\int_0 ^ y \int_{x_1} ^ y \cdots \int_{x_{n - 1}} ^ y \prod\limits_{i = 1} ^ n \left(y ^ A + \sum\limits_{j = i + 1} x_j ^ A\right) \mathrm{d} x_1 \mathrm{d} x_2 \cdots \mathrm{d} x_n \\ &= n!y ^ {n(A + 1)}\int_0 ^ y \int_{x_1} ^ y \cdots \int_{x_{n - 1}} ^ y \prod\limits_{i = 1} ^ n \left(1 + \sum\limits_{j = i + 1} \left(\frac{x_j}{y}\right) ^ A\right) \mathrm{d} \left(\frac{x_1}{y}\right) \mathrm{d} \left(\frac{x_2}{y}\right) \cdots \mathrm{d} \left(\frac{x_n}{y}\right) \\ &= n!y ^ {n(A + 1)}\int_0 ^ 1 \int_{x_1} ^ 1 \cdots \int_{x_{n - 1}} ^ 1 \prod\limits_{i = 1} ^ n \left(y ^ A + \sum\limits_{j = i + 1} x_j ^ A\right) \mathrm{d} x_1 \mathrm{d} x_2 \cdots \mathrm{d} x_n = a_n(1)y ^ {n(A + 1)} \\ \end{aligned} \]

是关于 \(y\) 的单项式!再回到递归求解的部分,为了方便集合划分的枚举,考虑 \(\rm EGF\) 添加集合大小占位符 \(x\),令 \(f(x, y) = \sum\limits_n \frac{a_n(y)}{n!}x^n\)

对每个集合内部需要先钦定根,然后枚举根随机的实数,故集合内部的 \(\rm EGF\) 为:

\[y ^ A\sum\limits_n \frac{(n + 1)\int_0 ^ y a_n(t) \mathrm{d}t}{(n + 1)!}x ^ {n + 1} = xy ^ A\int_0 ^ y f(x, t) \mathrm{d}t \]

\(\exp\) 组合意义,\(f(x, y) = \exp\left(xy ^ A\int_0 ^ y f(x, t) \mathrm{d}t\right)\),故:

\[f(x, y) = \exp\left(xy ^ A \int_0 ^ y \sum\limits_n \frac{a_n(1)t ^ {n(A + 1)}}{n!}x ^ n \mathrm{d}t \right) = \exp\left(\sum\limits_n \frac{a_n(1)}{n!(n(A + 1) + 1)}x ^ {n + 1}y ^ {(n + 1)(A + 1)} \right) \]

注意到 \(f(x, y) = \sum\limits_n \frac{a_n(1)}{n!}(xy ^ {A + 1}) ^ n\),令 \(z = xy ^ {A + 1}, b_n = \frac{a_n(1)}{n!}\),由上式,令:

\[g(z) = \sum\limits_n b_nz ^ n = f(x, y) = \exp\left(\sum\limits_n \frac{b_n}{n(A + 1) + 1}z ^ {n + 1} \right) \]

两边求导得递推式:

\[\begin{aligned} & g'(z) = \sum\limits_n (n + 1)b_{n + 1}z ^ n = \left(\sum\limits_n b_nz ^ n\right)\left(\sum\limits_n \frac{(n + 1)b_n}{n(A + 1) + 1}z ^ n\right) \\ &\Rightarrow b_{n + 1} = \frac{1}{n + 1}\sum\limits_i ^ n \frac{(i + 1)b_ib_{n - i}}{i(A + 1) + 1} \end{aligned} \]

直接暴力即可,复杂度 \(\mathcal{O}(n ^ 2)\),也可以用半在线卷积优化到 \(\mathcal{O}(n \log ^ 2 n)\)

posted @ 2024-07-31 12:32  Achtoria  阅读(32)  评论(0编辑  收藏  举报