Solution Set -「ABC 217」
大家好屑兔子又来啦!
【A - Lexicographic Order】
说个笑话,\(\color{black}{\text{W}}\color{red}{\text{alkingDead}}\) 和 \(\color{black}{\text{O}}\color{red}{\text{neInDark}}\) 在这题各罚了两次时,我因为不会所以没有被罚。
【B - AtCoder Quiz】不会。
【C - Inverse of Permutation】不会。
【D - Cutting Woods】
我本来不会的,但上次都是从 D 开始讲的所以就……
用 std::set 维护切割点,标记 \(x\) 所在段的长度就是它在集合里的后继减去前驱。
- 参考代码。
【E - Sorting Queries】
讲个笑话,我以为 std::merge 的复杂度是较短容器的长度。
基础的势能算法吧,用 std::multiset 维护前缀有序段,用队列维护其他无序元素。进行排序操作时暴力把队列全部塞到 set 里即可。
- 参考代码。
【F - Make Pair】
讲个笑话,我一度想要优化一个睿智的 \(\mathcal O(n^4)\) DP。
看到“相邻配对删除”,应该想到区间 DP,并且利用“在某一时刻相邻而现在不相邻”这一条件将序列划分为独立子问题。
令 \(f(l,r)\) 表示将区间 \([l,r]\) 内的人全部配对的方案数(那么自然需要 \(2\mid(r-l+1)\))。转移时枚举与 \(l\) 配对的人 \(i\),得到转移
\]
其中有边界 \(f(i,i+1)=1\)。组合数对应这个计数场景:“左边有 \(a\) 次操作,右边有 \(b\) 次操作,\((l,i)\) 还有一次配对操作,且必须在左边 \(a\) 次完成后进行”,那么把这一次归类为第 \(a+1\) 次左边操作,方案数即为 \(\binom{a+1+b}{b}\)。复杂度为 \(\mathcal O(n^3)\)。
- 参考代码。
【G - Groups】
为什么 G 永远比 F 简单,永远是计数问题,永远存在更优秀的多项式算法。(其实上次就不是。
还是想象成把球(人)放进盒子(组)里会比较舒服。我们忽略掉题目中要求“盒子相同”“盒子非空”的要求之后,会发现此时的方案数就是组合数的若干次方。具体地,我们能求得 \(f_i\) 表示将这些球放进至少 \(i\) 个盒子里,且非空的盒子本质不同的方案数,有
\]
其中 \(A_n^m=\binom{n}{m}m!\) 即 \(n\) 个里选 \(m\) 个排列的方案数,\(n<m\) 时值为 \(0\)。
此后,令答案为 \(g_i\),根据组合意义(我当时随便凑了几个式子过样例就交了√),可以得到 \(g\) 的表达式
\]
由于是 ABC,直接递推出这个东西就可以 \(\mathcal O(n^2)\) 求解了。
不过,显然可以用分治 FFT 优化至 \(\mathcal O(n\log^2 n)\)。我写出来大概是十倍速度。但是最优解貌似是 \(\mathcal O(n\log n)\),仅用一次卷积的做法,有空研究√
UPD: 谢谢,移项之后就是 \(e^x G=F\) 了,确实可以直接卷,我是屑。
【H - Snuketoon】
令 \(f_i(x)\) 表示前 \(i\) 次射击后,站在 \(x\) 位置,受到的最小伤害。注意水枪伤害的性质,我们断言 \(f_i(x)\) 的是下凸的。虽然不难证明,但的确是本题的重点。
所以,可以用两个 std::multiset 维护左半凸壳和右半凸壳的转折点,并保证转折点两侧的斜率差为 \(1\)(所以需要维护重点)。那么转移过程中,我们需要完成一次整体取邻域最小值和叠加一段斜率为 \(\pm 1\) 的一次函数。维护一下就好√
- 参考代码。
Solution Set -「ABC 217」的更多相关文章
- Solution -「ABC 217」题解
D - Cutting Woods 记录每一个切割点,每次求前驱后驱就好了,注意简单判断一下开闭区间. 考场上采用的 FHQ_Treap 无脑莽. #include <cstdio> #i ...
- Diary / Solution Set -「WC 2022」线上冬眠做噩梦
大概只有比较有意思又不过分超出能力范围的题叭. 可是兔子的"能力范围" \(=\varnothing\) qwq. 「CF 1267G」Game Relics 任意一个 ...
- Solution Set -「ARC 107」
「ARC 107A」Simple Math Link. 答案为: \[\frac{a(a+1)\cdot b(b+1)\cdot c(c+1)}{8} \] 「ARC 107B」Quadrup ...
- Solution -「ABC 219H」Candles
\(\mathcal{Description}\) Link. 有 \(n\) 支蜡烛,第 \(i\) 支的坐标为 \(x_i\),初始长度为 \(a_i\),每单位时间燃烧变短 \(1\) ...
- Solution -「ABC 215H」Cabbage Master
\(\mathcal{Description}\) Link. 有 \(n\) 种颜色的,第 \(i\) 种有 \(a_i\) 个,任意两球互不相同.还有 \(m\) 个盒子,每个盒子可以被放 ...
- Solution -「ABC 213G」Connectivity 2
\(\mathcal{Description}\) Link. 给定简单无向图 \(G=(V,E)\),点的编号从 \(1\) 到 \(|V|=n\).对于 \(k=2..n\),求 \(H= ...
- Solution -「ABC 213H」Stroll
\(\mathcal{Description}\) Link. 给定一个含 \(n\) 个结点 \(m\) 条边的简单无向图,每条边的边权是一个常数项为 \(0\) 的 \(T\) 次多项式, ...
- 「ABC 249Ex」Dye Color
考虑停时定理. 初始势能为 \(\sum \Phi(cnt_i)\),末势能为 \(\Phi(n)\),我们希望构造这样一个 \(\Phi:Z\to Z\) 函数,使得每一次操作期望势能变化量为常数. ...
- Note -「Lagrange 插值」学习笔记
目录 问题引入 思考 Lagrange 插值法 插值过程 代码实现 实际应用 「洛谷 P4781」「模板」拉格朗日插值 「洛谷 P4463」calc 题意简述 数据规模 Solution Step 1 ...
随机推荐
- Linux命令查看各端口号占用情况
yum -y install net-tools netstat -ntpl
- Could not find resource mybatis.xml 找不到mybatis主配置文件的三种解决方式
第一种:先清除target目录 再重新compile编译 第二种:让idea重构项目 第三种 :手动添加到target目录下的classes包下
- 【记录一个问题】MariaDB 10.1.9 中with rollup的神器问题
我想统计每天数据的处理状态的汇总,于是写了这样一条语句: 1 select * from ( 2 select ifnull(date(update_time),'_30天汇总') as dtm, i ...
- 关于BIO NIO和AIO的理解
转载自 :http://blog.csdn.net/anxpp/article/details/51512200 1.BIO编程 1.1.传统的BIO编程 网络编程的基本模型是C/S模型,即两个进程间 ...
- Prometheus-operator 介绍和配置解析
随着云原生概念盛行,对于容器.服务.节点以及集群的监控变得越来越重要.Prometheus 作为 Kubernetes 监控的事实标准,有着强大的功能和良好的生态.但是它不支持分布式,不支持数据导入. ...
- Vue框架怎么使用mediainfo.js来检测视频文件是否有音轨?
啥是MediaInfo? 简而言之,MediaInfo是一个能读取音频和视频文件并分析和输出音视频信息的工具,能输出的内容包括视频信息,音轨,字幕等. MediaInfo也可以在web端使用,需要使用 ...
- MySQL基本使用(开机自启动-环境变量-忘记密码-统一编码)
目录 一:mysql简介 1.什么是MySQL? 2.MySQL的本质 3.MySQL的特点与优势 二:基本操作命令 1.登录服务端 2.2.结束符c 3.查看当前所有的库名称 4.取消之前的命令 5 ...
- WEB前端基础之SCC(字体颜色背景-盒子模型)
目录 一:伪元素选择器 1.首字调整>>>:也是一种文档布局的方式 2.在文本的前面通过css动态渲染文本>>>:特殊文本无法选中 3.在文本的后面通过css动态渲 ...
- PC端实用正版软件推荐
首先介绍一下背景,我本人是一个软件工程师,所以对电脑上很多软件使用都有要求,这里将个人觉得好用的一些软件分享给大家: 1. Typora 对于长写本地笔记.网络博客的人,对 MarkDown 格式应该 ...
- th 表达式的简单使用。
一.使用场景,页面中,循环遍历,获得控制器穿过来的值. 1.1 控制器 /** * 获得所有的图书信息 * @return */ @RequestMapping("/turnIndexPag ...