ABC246
A,B,C 都是语法题,跳了。
D 就是考虑两个数都不超过 ,所以就枚举一个,二分另外一个。
前四题都水就没写。
E
我不会下国际象棋。
象只能斜着走,可以走任意长的距离,问最少能走到目标位置的步数。
01 BFS 。
我们记录上一次走过来的方向,如果相同就说明这一次可以和上一次算作一步,这次走的距离就算作 ,不同就说明需要不能和上一步合并,所以距离算作 。然后就转化成了 01 BFS
F
容斥原理。
就相当于我们要求所有字母可能出现的情况的并集。考虑字母只来自一个字符串,这些字符串构成的不同种情况中可能有交集,所以要减掉交集,然后就转化成了容斥原理的模型。
G
这是一道模拟赛题。
我找找我当时写没写小记
Ex
我之前听说外国人不会科技
首先考虑不带修的方案数。
设 表示到第 个位置,以 结尾的方案数。
然后如果当前位置是 的话,。
如果当前位置是 的话,。
问号就各把他们当作 或 重算一次。
如果当前位置和 相同的话考虑把他们接到上一段或者另起一段。不会算重是因为我们的策略是所有前面开头后面都会接上。
把式子合并起来长这样 。
考虑如何让他带修。
DDP!
我们构造一个转移矩阵。
就是让 乘上一个矩阵后变成 。
因为式子种有加一的项,所以两行可能不够用,所以我们加一行为 的行。
于是我们可以构造出
我他喵的发现这里写反了,结果矩乘的规则让我直接改了,变成前面的每一列成后面的每一行了(((
额他不影响,就知道是这样构造的就行。
然后把转移矩阵架到线段树上就能快速修改和转移了。
本文作者:cc0000
本文链接:https://www.cnblogs.com/cc0000/p/16815258.html
版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步