- VisualStudio2022插件的安装及使用-编程手把手系列文章
- pprof-在现网场景怎么用
- C#实现的下拉多选框,下拉多选树,多级节点
- 【学习笔记】基础数据结构:猫树
参考了出题人题解和 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\limits_c\) 置之不理.
我们设对于所有 \(c_{i,j}\) 的出现下标构成的集合为 \(S_i\),那么可以得到这样一个式子.
考虑外层 \(\sum_{c}\) 的影响,显然第一维不同的 \(c\) 之间互不影响.
先将外层乘积 \(\prod_{i=1}^{n}\) 展开为若干 \(n\) 次单项式的和,针对每个单项式,我们考虑 \(c_{i,j}\) 的约束即 \(\sum_j c_{i,j} = a_i\).
利用乘法分配律,分别对每个 \(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\),那么总生成函数为:
简化得到:
为了求往 \(r_i\) 个盒子中放入 \(a_i\) 个球的贡献,我们需要找到生成函数 \(G(x)\) 中 \(x^{a_i}\) 的系数:
这等价于:
对 \(\frac{1}{(1-x)^{s_i + r_i}}\) 展开,得到:
将这一展开式代入 \(G(x)\) 中:
为了找到 \(x^{a_i}\) 项,需要满足 \(n + s_i = a_i\),可以得知 \(n = a_i - s_i\).
代入可以得到 \(x^{a_i}\) 项的系数为:
可以发现结果只受到 \(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}\) 表示一下含义:
然后根据前半段和后半段的不同情况分别处理.
我们对前半段的 \(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」清明的文章就讲到这里了,如果你想了解更多关于【解题报告】P8478「GLR-R3」清明的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
@After public void afterScenario() { if (ScenarioManager.getScenario().isFailed()) {
我已将 BIRT 报告集成到 Grails 中并设计了一份报告。我的 grails 应用程序中有一个名为 startPeriod (仅限月份和年份)的参数,我想将其传递给 BIRT。然后 BIRT 调
我有一些 Oracle 报告 (.rdf),正在考虑将其转换为 BIRT 报告。有没有办法将 .rdf 文件转换为 BIRT 报告设计文件? 最佳答案 完全自动化的解决方案可能是不可能的。您可以部分自
当 gcc 4.1(使用 gcov)下一行: p = 新类; 报告为 100% 分支覆盖率 为什么? 因为启用了异常处理!!! 为了解决此问题,请指定: -fno-exceptions 在 g++
真的有好 免费 BugZilla 报告工具?我发现 Web 界面上的默认搜索选项太有限了。我最大的问题是缺少 Order By 选项(一次只有 1 个字段,可供选择的字段集非常有限)。我已经做了一些谷
是否可以在 CFMX7 上运行 ColdFusion Report builder 生成的报告? 更明确地说,是否可以将 CF7 中的报告生成引擎更改为 CF8? 最佳答案 我猜这可能很难做到。我记得
根据Lucintel发布的新市场报告,智能家居市场的未来看起来很有吸引力,在家用安全、家电、娱乐、照明、HVAC、医疗保健和厨房应用中将带来许多机遇。 由于COVID-19导致的全球经济衰退,
PHPCodeSniffer 是否生成 HTML 报告? 如果不是呢?怎么办? 目前,我可以运行 PHPCodeSniffer,但它只生成 XML 文件并在终端中显示结果。 如何在 phpunit 中
我在一个包中添加了一个简单的测试。 按照手册中的建议,我尝试让 PHPUnit 加载配置: phpunit -c /app phpunit.xml 看起来像这样:
我有两个从 csv 文件加载的数据框。基本上来自不同的环境但格式/列相似,它们的行/值可能有所不同。我想找到差异并在新的数据框中创建它们。两个数据框也将具有相同的顺序。我有 100 个要比较的文件。提
我想看看是否有办法通过 javadoc 在我的 junit 报告中包含“描述性文本”。 JUnit 4 似乎不像 TestNG 那样支持 @Test 注释的“描述”属性。 到目前为止,我所研究的只有一
我正在使用操作、 Controller 、servlet struts 框架编写 Excel 报告。该报告非常拥挤,已经有大约 10 个单独的查询。由于报告发生变化,我需要再添加大约 10 个查询。有
在放弃 Syleam 的 openerp jasper 模块后,我在 Nan Tic 的 jasper_reports 模块上苦苦挣扎。 它一直给我一个错误: File "C:\Program Fil
我希望创建一个简单的日历。每天由编码器生成条目计数并以日历样式查看。如一月、二月等。或按月显示全年。 database have date_added and encoder columns 我在将它
我必须为报告创建 MySQL 查询。 我有一个表history,它记录产品订单的状态更改。我有订单生命周期(订单流程)的以下状态:新、已确认、正在处理、已发货、已交付、已取消、已退回。订单不一定遵循此
如何将多个查询合并为一个? 例如: //Successful Sales: SELECT username, count(*) as TotalSales, sum(point) as Points
MySQL 优化技术的新手。请找到下面的 mysqltuner.pl 报告,并建议我应该更改 my.cnf 中的哪些变量以优化性能。 还有一个问题- 我无法在我的 my.cnf 中找到一些变量,例如
我想知道,我想将我的 Swing Worker 的某种形式的进度报告回主线程,以便我的界面可以使用随着进度增加而变化的标签进行更新,例如 checking 1/6... checking 2/6...
我正在尝试在“报告”>“销售”下运行 Magento Paypal 结算报告,但每次我尝试运行该报告时,我都会收到消息“由于配置为空,无法获取任何内容” 我查看了“系统”>“配置”>“销售”>“付款方
我想要一个工具来帮助创建 sql 查询(对于非 IT 人员),例如 dbforge。 我希望我们的非 IT 人员(例如运营)创建他们自己的 sql 查询。 我的第二个目标是让他们能够按需执行这些查询。
我是一名优秀的程序员,十分优秀!