P8478 「GLR-R3」清明

参考了出题人题解xcyyyyyy 大神的题解,强推前两篇。

拿到题完全没思路怎么办???

人类智慧的巅峰,思维量的登峰造极。

换句话说就是非人题目,不过不得不说 GLR 的题是真的好,难度也是真的高。

首先我们需要看懂题面,这是第一个难点。

题面大意如下:

对于一个雨滴,它可以向任意编号小于等于 \(\min\{i+k,n\}\) 的台阶上移动,而其对应的一部分容量也会在移动后修改至其移动后的台阶。

同时雨滴体积不会莫名其妙减少或者增多。

而在「下一个瞬间」其对应的奇妙度为 \(\prod\limits_{i=1}^{n}a_i'\)。

求所有本质不同的「下一个瞬间」的奇妙度总和。

考虑从数据范围入手。

  • Subtask 5

    对于 \(k=1\),在此情况下每个台阶上的雨滴最多只会向下移动一个台阶。

    我们定义 \(c_i\) 为第 \(i\) 个台阶向下一阶流动的雨水容量。

    那么我们就可以知道 \(a_i'=a_i+c_{i-1}-c_i\)。

    可以发现 \(ans=\sum\limits_{c}\prod\limits_{i=1}^{n}(a_i+c_{i-1}-c_i)\)。

    考虑多项式展开,对于内部的 \(a_i+c_{i-1}-c_i\) 我们直接划分为两部分:\(a-c_i\) 和 \(c_{i-1}\)。

    此时我们推广到积就会得到很多项 \(a-c_i\) 和 \(c_{i-1}\) 的和,我们再引入一个子集 \(S\subseteq\{1,2,3,\cdots,n\}\)。

    每个 \(i\in S\) 代表在 \(a_i-c_i\) 中选取,否则代表在 \(c_{i-1}\) 中选取。

    那么我们也就发现 \(\prod\limits_{i=1}^{n}(a_i+c_{i-1}-c_i)=\sum\limits_{S\subseteq \{1,2,\cdots,n\}}\prod\limits_{i\in S} (a_i-c_{i})\prod\limits_{i\not\in S}c_{i-1}\)。

    整体式子也就得到了 \(ans=\sum\limits_{c}\sum\limits_{S\subseteq \{1,2,\cdots,n\}}\prod\limits_{i\in S} (a_i-c_{i})\prod\limits_{i\not\in S}c_{i-1}\)。

    我们考虑去掉外层的 \(\sum\limits_{c}\),策略就是把下标 \(c_i\) 相同的一批都合成到一起。

    当 \(i<n\) 时,考虑 \(i\) 和 \(i-1\) ,定义 \(f_{i,1}\) 为包含 \(i\) 的所有 \(S\) 的乘积之和,\(f_{i,1}\) 为不包含 \(i\) 的所有 \(S\) 的乘积之和,我们就可以分成 \(4\) 个情况来转移。

    • \(i - 1 \in S, i \in S\)

      贡献是 \(\sum\limits_{0\le c_i \le a_i}(a_i-c_i)=\frac{a_i(a_i+1)}{2}\)。

    • \(i - 1 \not \in S, i \in S\)

      贡献是 \(\sum\limits_{0\le c_i \le a_i} 1 = a_i+1\)。

    • \(i - 1 \in S, i \not \in S\)

      贡献是 \(\sum\limits_{0\le c_i \le a_i}(a_i-c_i)c_i = \frac{a_i^2(a_i+1)}{2}-\frac{a_i(a_i+1)(2a_i+1)}{6} = \frac{(a_i-1)a_i(a_i+1)}{6}\)。

    • \(i - 1 \not \in S, i \not \in S\)

      贡献是 \(\sum\limits_{0\le c_i \le a_i}c_i=\frac{a_i(a_i+1)}{2}\)。

    那么我们就可以直接递推的从 \(f_{i-1,0/1}\) 向 \(f_{i,0/1}\) 转移。

    这样我们就终于完成了拿到了 13 pts,复杂度 \(O(n)\)。

  • Subtask 6

    考虑从 Sub5 进行推广, \(c_i \to c_{i,j}\) 代表第 \(i\) 个台阶到第 \(i+j\) 个台阶流动的量,然后就能拿到一个能拆的式子。

    \[\sum_{c}\prod_{i=1}^{n}\left(\sum_{j=0}^{\min(i-1,k)}c_{i-j,j}\right)
    \]

    然后再推好像就好点,我们继续展开。

    依然是先把 \(\sum\limits_c\) 置之不理。

    我们设对于所有 \(c_{i,j}\) 的出现下标构成的集合为 \(S_i\),那么可以得到这样一个式子。

    \[\prod_{i=1}^n\prod_{j\in S_i}c_{i,j}
    \]

    考虑外层 \(\sum_{c}\) 的影响,显然第一维不同的 \(c\) 之间互不影响。

    先将外层乘积 \(\prod_{i=1}^{n}\) 展开为若干 \(n\) 次单项式的和,针对每个单项式,我们考虑 \(c_{i,j}\) 的约束即 \(\sum_j c_{i,j} = a_i\)。

    利用乘法分配律,分别对每个 \(i\) 维度的 \(c_{i,j}\) 进行求和,最终我们可以收拢成一个和式。

    \[\prod_{i=1}^n\sum_{c_i}\left[\sum_{j}c_{i,j}=a_i\right]\prod_{j\in S_i}c_{i,j}
    \]

    这好像不是很好做啊,那我们可以构建一个组合意义来简化题面。

    我们用 \(r_i\) 表示对于任意合法的 \(j\),\(c_{i,j}\) 中有 \(r_i\) 个变量可以取到非 \(0\) 值,也就是说 \(r_i=\min(n-i,k)+1\)。

    那么我们就可以建立这样的模型:

    有编号为 \(0,1,2,\dots,r_i-1\) 的 \(r_i\) 个盒子。

    其中编号落在属于 \(S_i\) 的盒子,放了 \(x\) 个球会贡献 \(x\)。

    而其它盒子无论放多少个球,贡献都是 \(1\)。

    一种方案的贡献为各个盒子的贡献的积。

    求往 \(r_i\) 个盒子中任意放 \(a_i\) 个没有任何区别的球的贡献之和。

    虽然还是不好做,但是起码可以构建生成函数了不是吗?

    我们可以发现我们并不关心 \(S_i\) 具体是多少,我们只关心 \(|S_i|\)。

    我们构造生成函数来实现,对于编号在 \(S_i\) 中的盒子,这些盒子的特点是放 \(x\) 个球的贡献是 \(x\),生成函数为 \(\frac{x}{(1-x)^2}\),将球放进盒子时,贡献会随着球的数目成比例增加。

    剩下的盒子,这些盒子的特点是不论放多少球,贡献始终为 \(1\),因此其生成函数为 \(\frac{1}{1-x}\),球的数目对贡献无影响,但我们仍然允许球被放进去。

    将这些生成函数组合在一起,让 \(|S_i| = s_i\),那么总生成函数为:

    \[G(x) = \left( \frac{x}{(1 - x)^2} \right)^{s_i} \cdot \left( \frac{1}{1 - x} \right)^{r_i - s_i}
    \]

    简化得到:

    \[G(x) = \frac{x^{s_i}}{(1 - x)^{s_i + r_i}}
    \]

    为了求往 \(r_i\) 个盒子中放入 \(a_i\) 个球的贡献,我们需要找到生成函数 \(G(x)\) 中 \(x^{a_i}\) 的系数:

    \[ [x^{a_i}] G(x) = [x^{a_i}] \frac{x^{s_i}}{(1 - x)^{s_i + r_i}}
    \]

    这等价于:

    \[ [x^{a_i - s_i}] \frac{1}{(1 - x)^{s_i + r_i}}
    \]

    对 \(\frac{1}{(1-x)^{s_i + r_i}}\) 展开,得到:

    \[\frac{1}{(1-x)^{s_i + r_i}} = \sum_{n=0} \binom{n + s_i + r_i - 1}{s_i + r_i - 1} x^n
    \]

    将这一展开式代入 \(G(x)\) 中:

    \[\begin{aligned}
    G(x) &= x^{s_i} \sum_{n=0} \binom{n + s_i + r_i - 1}{s_i + r_i - 1} x^n\\
    &= \sum_{n=0} \binom{n + s_i + r_i - 1}{s_i + r_i - 1} x^{n + s_i}
    \end{aligned}
    \]

    为了找到 \(x^{a_i}\) 项,需要满足 \(n + s_i = a_i\),可以得知 \(n = a_i - s_i\)。

    代入可以得到 \(x^{a_i}\) 项的系数为:

    \[\binom{(a_i - s_i) + s_i + r_i - 1}{s_i + r_i - 1} = \binom{a_i + r_i - 1}{s_i + r_i - 1}
    \]

    可以发现结果只受到 \(S_i\) 的影响,上面已经提到了,我们考虑 \(s_i\) 是怎么来的。

    可以发现每个 \(i\) 会向集合 \(\max\{i-k,1\} \le j \le i\) 的某个盒子 \(j\) 恰好贡献 \(S_j\)。

    因此每个 \(i\) 在对应区间内,只会贡献一次。

    每个 \(i\) 的贡献可以由多个位置 \(j \in (i,i+k)\) 贡献,可以反过来理解:

    实际上每个 \(s_i\) 可以从 \(\{i, i+1, \dots, i+r_i-1\}\) 这些位置中任选一个贡献。

    进行 \(dp\) 即可,设 \(f_{i,j}\) 表示在后缀 \(i\) 中有 \(j\) 个位置没有贡献过 \(s\) 的权值和。

    转移就枚举一下 \(s\) 然后组合数计算,复杂度 \(O(n^3)\)

  • Subtask 7

    拓展 Subtask 6 中的处理方法,考虑状压。

    设 \(f_{i,S}\),用 \(i\) 表示当前后缀,用 \(S\) 表示 \(i,i+1,i+2,\dots,\min(i+k,n)\) 是否已经都贡献过 \(s\),复杂度 \(O(n\cdot 3^k)\) 是过不去的。

    那咋办?注意到 \(i\) 的贡献只和 \(S\) 中新增的已经贡献过的位置个数有关,并且能贡献到 \(S\) 的前驱状态 \(T\) 得满足 \(T\subseteq S\),因此我们可以直接做高维前缀和,同时记录一下新增个数即可。

    复杂度 \(O(n\cdot k^2\cdot 2^k)\),可以通过 Subtask 7。

  • Subtask 8

    直接莽 \(O(n\cdot k^2\cdot 2^k)\)!欸过不去,考虑优化。

    发扬人类智慧,我们发现在 \(k\) 较大的时候只有较少的台阶会超出限制,大多数问题集中在一部分位置

    我们如果在 \(k\) 和 \(k+1\) 处对前后分成两部分的话,枚举后半段位置是否被前半段占用,从而使得前后的贡献分开计算。这样每一段的内部贡献就独立了

    因为前半段的贡献不会超出限制,因此每个内部后缀都可以贡献,问题转化为类似 Subtask 6 的形式

    考虑动态规划, \(f_{i,j,S}\) 表示一下含义:

    • \(i\): 从后缀 \(i\) 开始。
    • \(j\): 在区间 \([i, k]\) 中,尚未被占用的位置数。
    • \(S\): 表示区间 \((k, n]\) 中的位置占用情况。

    然后根据前半段和后半段的不同情况分别处理。

    我们对前半段的 \(j\) 做类似 Sub6 的转移,对 \(S\) 做类似 Sub7 的转移。

    对于后半段,我们枚举 \(S\) 来做类似 Sub6 的转移。

    复杂度为 \(O(n\cdot k^2\cdot \sqrt k\cdot 2^k)\)。

  • Subtask 9

    Sub8 的做法又过不去了?

    我们引入容斥思想来优化 Sub8 的做法,为了优化算法,我们枚举后半段 \((k+1,n]\) 中的位置是否被超出限制占用。

    我们用状态 \(f_{i,j}\) 来表示后缀 \(i\) 中有 \(j\) 个位置是可选的但未被占用

    在状态转移时,从 \(f_{i+1}\) 转移到 \(f_i\) 时,不仅要考虑位置 \(i\) 是否被加入,还需要考虑位置 \(i+k+1\) 是否被加入,和 Sub6 类似,但需要结合对后段的枚举。

    这样我们就解决了 Sub9,复杂度 \(O(n^2\cdot k\cdot 2^{n-k})\)。

现在我们解决了所有的 Subtask,我们将 Sub7 和 Sub9 进行结合即可通过本题。

【解题报告】P8478 「GLR-R3」清明的更多相关文章

  1. 「ZJOI2016」解题报告

    「ZJOI2016」解题报告 我大浙的省选题真是超级神仙--这套已经算是比较可做的了. 「ZJOI2016」旅行者 神仙分治题. 对于一个矩形,每次我们从最长边切开,最短边不会超过 \(\sqrt{n ...

  2. 「THUSCH 2017」大魔法师 解题报告

    「THUSCH 2017」大魔法师 狗体面太长,帖链接了 思路,维护一个\(1\times 4\)的答案向量表示\(A,B,C,len\),最后一个表示线段树上区间长度,然后每次的操作都有一个转移矩阵 ...

  3. 「AHOI / HNOI2018」转盘 解题报告

    「AHOI / HNOI2018」转盘 可能是我语文水平不太行... 首先可以猜到一些事实,这个策略一定可以被一个式子表示出来,不然带修修改个锤子. 然后我们发现,可以枚举起点,然后直接往前走,如果要 ...

  4. 「CTS2019 | CTSC2019」氪金手游 解题报告

    「CTS2019 | CTSC2019」氪金手游 降 智 好 题 ... 考场上签到失败了,没想容斥就只打了20分暴力... 考虑一个事情,你抽中一个度为0的点,相当于把这个点删掉了(当然你也只能抽中 ...

  5. 「CTS2019 | CTSC2019」随机立方体 解题报告

    「CTS2019 | CTSC2019」随机立方体 据说这是签到题,但是我计数学的实在有点差,这里认真说一说. 我们先考虑一些事实 如果我们在位置\((x_0,y_0,z_0)\)钦定了一个极大数\( ...

  6. 「JOI2019 Final」解题报告

    传送门 「JOI2019 Final」勇者比太郎 看懂题就很简单了,后缀和随便维护一下就好了,别用树状数组强加一个\(\log\)就行. 「JOI2019 Final」画展 显然可以先把所有的画框按大 ...

  7. 「SOL」JOISC2021 解题报告

    JOIS(egment-Tree)C 1. 前言 很早之前教练让我们做这套题,我以为这套题应该挺简单,用几天的空余时间就能刷完,结果预想的短周期刷题变成了长周期刷题--(好像是整个团队里最后一个刷完的 ...

  8. 「TJOI / HEOI2016」字符串

    「TJOI / HEOI2016」字符串 题目描述 佳媛姐姐过生日的时候,她的小伙伴从某东上买了一个生日礼物.生日礼物放在一个神奇的箱子中.箱子外边写了一个长为 \(n\) 的字符串 \(s\),和 ...

  9. 「BZOJ 4228」Tibbar的后花园

    「BZOJ 4228」Tibbar的后花园 Please contact lydsy2012@163.com! 警告 解题思路 可以证明最终的图中所有点的度数都 \(< 3\) ,且不存在环长是 ...

  10. 「BZOJ 3645」小朋友与二叉树

    「BZOJ 3645」小朋友与二叉树 解题思路 令 \(G(x)\) 为关于可选大小集合的生成函数,即 \[ G(x)=\sum[i\in c ] x^i \] 令 \(F(x)\) 第 \(n\) ...

随机推荐

  1. springboot实现登录demo

    实现简单的登录功能 实体类 定义实体类为User3类. 使用@Data:提供类的get,set,equals,hashCode,canEqual,toString方法: 使用@AllArgsConst ...

  2. cf edu 133 D

    题意 思路 根据题意,最开始可以想到一个二维的dp状态 用dp[i][j]表示跳了j次刚好到i的方案数 如果是跳了j次,那么这次应该要被k+j-1整除才行 那么这样状态转移就是 dp[i][j] = ...

  3. 2 - 【RocketMQ 系列】CentOS 7.6 安装部署RocketMQ

    二.开始安装部署RocketMQ 官方网站:https://rocketmq.apache.org/ 各版本要求: 1.版本选取 下载地址: https://github.com/apache/roc ...

  4. Nginx 可视化配置神器NginxConfig

    Nginx 是前后端开发工程师必须掌握的神器.该神器有很多使用场景:比如反向代理.负载均衡.动静分离.跨域等等. 把 Nginx 下载下来打开 conf 文件夹的 nginx.conf 文件,Ngin ...

  5. 8行JS代码实现Vue穿梭框

    实现效果 完整 demo 参考 <template> <div class="contain"> <ul class=""> ...

  6. [oeasy]python0052_ raw格式字符串_单引号_双引号_反引号_ 退格键

    转义字符 回忆上次内容 最近玩的是\n.\r 之外的转义序列 \a是 ␇ (bell) \t是 水平制表符 \v是 换行不回车 通过 16 进制数值转义 \xhh 把(hh)16 进制对应的 asci ...

  7. Java 中的一些知识点

    Java 中的一些知识点 Java 中的知识点 与C++相关 toString方法 super 与C++相关[了解的不是很多] 在Java程序中:一个方法以 ; 结尾,并且修饰符列表中有 native ...

  8. 配置Sprig security后Post请求无法使用

    在学习过程中发现在配置完Spring security后,Post请求失效,无法增删改数据,这里可以通过在Spring Security 的Config类中增加 也可以自定义csrf,不过目前还不是很 ...

  9. scanf、cin及其优化、快读性能测试

    为了让大家了解C++各种IO方式的性能,于是就有了这篇文章. 本次测试采取的数据均为 \(10^6\) 个不超过 \(10^8\) 随机正整数. 测试代码: #include<bits/stdc ...

  10. 阅读翻译Mathematics for Machine Learning之2.8 Affine Subspaces

    阅读翻译Mathematics for Machine Learning之2.8 Affine Subspaces 关于: 首次发表日期:2024-07-24 Mathematics for Mach ...