NOIP 模拟赛:2024-11-23
假算法轻取 96pts。
T1:
给定一个
;- 对
,至多一个 满足要求:点对 和 中,一对之间有边直接相连,另一对没有。即对排列中非两端的结点,至多一个和排列中的两侧邻点中恰一个有边直接连接。
请输出一个满足条件的排列。
"有
让每个人插入到当前序列的黑白交界处即可。
本题一样,让每个结点判断与交界处是否有边来决定去左边还是右边。
T2:
数轴上有
之后所有点开始运动,如果在时刻
可以发现会出现的碰撞事件
经典转化:碰撞并不是回头了,而是都继续往前走。
先把所有点按坐标排序。二分 + 双指针可以求出字典序
容易发现碰撞对象只可能是相邻两个球。同时
我们要找到(第
可以预处理
因为
如何快速找到第一次发生时间
坑点:最终可能有开头的几个时间字典序
T3:
求构造满足如下条件的
- 所有整数的取值范围为
; - 对
,以下两个条件至少一个成立: ; 。
答案对998244353取模。两个方案不同,当且仅当存在至少一个位置,使两个序列中该位置的数不相等。
妙题。对容斥集合直接 DP。
注意到不满足的条件很苛刻。如果
因此可以求出
既然不合法的情况这么少见,可以考虑容斥。怎么容?平时是 "至少
我们直接
如何转移?枚举
此时就已经有了
dp[i][0] += sc[j + 1] * dp[i - j - 1][j % 2] % MOD;
dp[i][0] %= MOD;
dp[i][1] += sc[j + 1] * dp[i - j - 1][1 - j % 2] % MOD;
dp[i][1] %= MOD;
复杂度
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!