CSP-S2019 题解
做了这套题,如果是让现在的我当时去考的话应该一共可以有 450 分,格雷码,括号树,树的重心都可以做,树上的数可以有 10 分,Emiya 至少可以有 76 分, 划分也可以有 64 分。看 OIerDB 上可以有 166 名的好成绩。
我的代码合集:洛谷 / 云剪贴板
[CSP-S2019] 格雷码
首先是格雷码有一个很好的生成方式,最低位 \(0110\) 的循环,次高位 \(00111100\) 的循环……
也就是说第 \(i\) 位由 \(2^{i}\) 个 \(0\),\(2^{i + 1}\) 个 \(1\),再来 \(2^i\) 个 \(0\) 来循环,并且这与总共有多少位是没有关系的!
那么我们就可以利用这个方法生成给定的第 \(k\) 个数,输出前 \(n\) 位即可。
[CSP-S2019] 括号树
首先我们考虑只有一条链怎么做。
将 () 看作 \(1 / -1\),做出前缀和序列。
那么对于每一个区间 \([l, r]\),为合法括号序列当且仅当 \(pre_{l - 1} = pre_r\) 并且 \(\min_{l \le i \le r} = pre_r\)。
于是可以利用单调栈,对于每一个右端点找到满足第二个条件的区间(也就是在前面第一个 \(\lt pre_r\) 后的左端点都满足第二个条件),顺便记录一下与栈顶相等的数的个数即可。
如果放在树上,我们只需要一个支持撤销的栈即可。
[CSP-S2019] 树上的数
抽象题,我只会 \(n!\) 和菊花图的做法 QwQ
[CSP-S2019] Emiya 家今天的饭
首先有一个很 naive 的 \(O(m n^3)\) DP,稍稍卡常应该是完全可以过的。
具体来说,我们发现之多只有一个不满足 \(\le \lfloor \frac k2 \rfloor\) 的食材,那么我们枚举这个食材是什么即可。
接下来,我们设 \(f_{i, j, k}\) 表示对于这个食材,考虑了前 \(i\) 种烹饪方法,选择了 \(j\) 种这个食材,一共选择了 \(k\) 种。那么枚举这一次的选择就可以转移了。
令 \(S_i\) 表示第 \(i\) 种烹饪方式有多少种选择,即 \(S_i = \sum a_{i, k}\),如果当前食材为 \(z\),那么转移为:
\]
最后我们只需要 \(\sum_{j \gt \lfloor \frac k2 \rfloor} f_{n, j, k}\) 即可。
然而这极度不优秀,将 \(j \le \lfloor \frac k2 \rfloor\) 转化为 \(j \gt k - j\),那么我们只需要 \(\sum_{j \gt k - j} f_{n, j, k}\) 即可,也就是我们只关注 \(j\) 与 \((k - j)\) 的差值,那么我们按照这个作为 DP 对象即可。
\]
这就是 \(O(m n^2)\) 的了,可以过。
[CSP-S2019] 划分
首先,\(O(n^2)\) 的 DP 是简单的,我们只需要记录 \(f_i\) 表示最小代价,\(g_i\) 表示使得为最小代价最后一段的最小值。
然而我们需要 \(O(n)\) QwQ,于是考虑 \(a^2 + b^2 \le (a + b)^2\),也就是我们需要使得划分出的段最多,那么只需要利用一个单调队列即可。
具体来说,我们需要找到 \(g_j \le pre_i - pre_j\) 的最大的 \(j\),也就是 \(g_j + pre_j \le pre_i\) 的 \(j\) 即可,由于 \(pre_i\) 是单调的,这容易利用单调队列维护。
[CSP-S2019] 树的重心
见我的另一篇文章:[CSP-S2019] 树的重心 题解
CSP-S2019 题解的更多相关文章
- 2019 CSP J/S第2轮 视频与题解
CSP入门组和提高组第二轮题解 转自网络
- 上午小测3 T1 括号序列 && luogu P5658 [CSP/S 2019 D1T2] 括号树 题解
前 言: 一直很想写这道括号树..毕竟是在去年折磨了我4个小时的题.... 上午小测3 T1 括号序列 前言: 原来这题是个dp啊...这几天出了好几道dp,我都没看出来,我竟然折磨菜. 考试的时候先 ...
- [CSP模拟测试43、44]题解
状态极差的两场.感觉现在自己的思维方式很是有问题. (但愿今天考试开始的一刻我不会看到H I J) A 考场上打了最短路+贪心,水了60. 然而正解其实比那30分贪心好想多了. 进行n次乘法后的结果一 ...
- 题解 nflsoj489 【六校联合训练 CSP #15】小D与随机
题目链接 考虑枚举好点的集合.此时要考虑的问题是如何填入\(1\sim n\)这些数使得恰好我们枚举到的这些点是好点,即:求出有多少种合法的填数方案. \(1\)号点一定是好点.那么除\(1\)号点外 ...
- CCF CSP 201703-3 Markdown
CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201703-3 Markdown 问题描述 Markdown 是一种很流行的轻量级标记语言(l ...
- CCF计算机职业资格认证考试题解
CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF计算机职业资格认证考试题解 CCF计算机软件能力认证(简称CCF CSP认证)是CCF计算机职业资格认证系 ...
- CCF CSP 201312-3 最大的矩形
CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201312-3 最大的矩形 问题描述 在横轴上放了n个相邻的矩形,每个矩形的宽度是1,而第i( ...
- CCF CSP 201609-3 炉石传说
CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201609-3 炉石传说 问题描述 <炉石传说:魔兽英雄传>(Hearthston ...
- CCF CSP 201403-3 命令行选项
CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201403-3 命令行选项 问题描述 请你写一个命令行分析程序,用以分析给定的命令行里包含哪些 ...
- CCF CSP 201709-4 通信网络
CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201709-4 通信网络 问题描述 某国的军队由N个部门组成,为了提高安全性,部门之间建立了M ...
随机推荐
- 力扣844(Java)-比较含退格的字符串(简单)
题目: 给定 s 和 t 两个字符串,当它们分别被输入到空白的文本编辑器后,如果两者相等,返回 true .# 代表退格字符. 注意:如果对空文本输入退格字符,文本继续为空. 示例 1: 输入:s = ...
- 【SIGIR 2022】面向长代码序列的Transformer模型优化方法,提升长代码场景性能
简介: 论文主导通过引入稀疏自注意力的方式来提高Transformer模型处理长序列的效率和性能 阿里云机器学习平台PAI与华东师范大学高明教授团队合作在SIGIR2022上发表了结构感知的稀疏注意力 ...
- 深度|为什么一定要从DevOps走向BizDevOps?
简介: 为更好地厘清波涛汹涌的数字化转型浪潮下软件产业所面对的机遇与挑战,6月29日,阿里云云效与阿里云开发者评测局栏目,联合特邀了InfoQ极客帮副总裁付晓岩.南京大学软件工程学院教授张贺.Thou ...
- RocketMQ 5.0: 存储计算分离新思路
简介: 在阿里云上,RocketMQ 的商业化产品也以弹性云服务的形式为全球数万个用户提供企业级的消息解决方案,被广泛应用于互联网.大数据.移动互联网.物联网等领域的业务场景,成为了业务开发的首选消息 ...
- Flink SQL 1.11 on Zeppelin 平台化实践
简介: 鉴于有很多企业都无法配备专门的团队来解决 Flink SQL 平台化的问题,那么到底有没有一个开源的.开箱即用的.功能相对完善的组件呢?答案就是本文的主角--Apache Zeppelin. ...
- 数据湖揭秘—Delta Lake
简介:Delta Lake 是 DataBricks 公司开源的.用于构建湖仓架构的存储框架.能够支持 Spark,Flink,Hive,PrestoDB,Trino 等查询/计算引擎.作为一个开放 ...
- 针对数据库连接池到DRDS连接探活的优化
简介: 针对数据库连接池到DRDS连接探活的优化 1. 问题背景 近期在给某专有云客户进⾏云产品应⽤性能优化分析时,发现了⼀个有趣的关于DRDS使⽤层⾯的问题,这⾥给⼤家分享⼀下.使⽤过DRDS产品的 ...
- 一文了解EPaxos核心协议流程
简介: EPaxos(Egalitarian Paxos)作为工业界备受瞩目的下一代分布式一致性算法,具有广阔的应用前景.但纵观业内,至今仍未出现一个EPaxos的工程实现,甚至都没看到一篇能把EPa ...
- [GPT] 使用 nodejs的 puppeteer 库使用完关闭后,linux上面有很多 chrome 进程
在使用 Node.js 的 Puppeteer 库时,如果你在使用完后关闭了浏览器,但在 Linux 上仍然存在很多 Chrome 进程,可能是因为没有正确地关闭所有相关的进程. 可以尝试以下方法 ...
- [GPT] 序列模型分类及其模型方案选择
序列模型可以分为两大类:线性序列模型和非线性序列模型. 线性序列模型:这类模型基于线性关系对时间序列进行建模和预测.常见的线性序列模型包括自回归模型(AR).移动平均模型(MA)和自回归移动平均模 ...