2024.7 #4 华夏风华 琢一番飞扬 待得开拓封疆 济沧桑 游目聘怀森森万象 沥肝胆 披阅九州的 风光
华夏风华 琢一番飞扬
待得开拓封疆 济沧桑
游目聘怀森森万象 沥肝胆
披阅九州的 风光
1. P7470 [NOI Online 2021 提高组] 岛屿探险
我们可以发现这个东西可以拆成很多个子问题,然后累计合并,这个东西可以使用线段树合并来做。
先考虑
-
,那么 和 的第 位必须相等,否则 ,然后直接往这个方向走即可。 -
,那么此时 和 的第 位任意取都行。那么就有两种可能:- 如果
和 的第 位不一样,那么此时 依然等于 ,所以我们向这个方向继续走即可。 - 如果
和 的第 位一样,那么此时 就会一定小于 了,那么对于答案的贡献就是这个子树里 的个数之和。
- 如果
这一部分就是 CF817E。比较简单。
接下来我们考虑
前面的是对于
具体的我们只需要把
当然我们不能每一次都建
然后我们考虑如何优雅的计算多组数据。
首先我们将
当然此时两个指针都往右移动。
2.Magic Breeding
我们先考虑特殊情况
然后我们发现取
那么我们要怎把
为
3.P5114 八月脸
截图选老婆
我们发现答案的形式是
然后再点分治的过程中记录每一个点到根节点的点权和为
- 先不考虑两个点在同一棵子树的情况计算最后再容斥掉。
- 逐子树加入,即考虑每棵子树对之前加入的子树的贡献。
- 利用合并果子,每次取出 size 最小的两个凸包,然后把两个合并起来。那么复杂度是
的。
明显的,前两种的维护都十分复杂,我们在此选择第三种。然后求出最终的凸包后直接二分求出最大值即可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
· 25岁的心里话