Codeforces 杂题选记
1864C Divisor Chain
反过来思考整个过程,我们尝试从 开始,给当前数加上自己的一个因数来凑出来 .
可以发现 的整数次幂是容易凑出的,因为任何数都是自己的因数,直接倍增即可.
如果我们凑出了 二进制表示下的最高位,那么 的其他位都是那个数的因数,而且都只被用了一次,那么直接凑上即可.
1864E Guess Game
考虑模拟决策过程.
由于二人没有头发,他们会从最高位开始考虑,那么轮数就是 和 二进制表示的 LCP 中 的个数乘 加 .
求期望直接求所有情况的轮数和,然后除 .
1858D Trees and Segments
不妨设 表示 最长连续段长度为 时,最长的 连续段的长度.那么对于一个 ,答案即为 .
考虑如何求出 ,首先我们可以钦定一个连续段 为 ,不妨设需要的修改次数为 ,那么我们要求的就是 这个前缀和 这个后缀中,修改 次能够得到的最长 连续段,这个也可以简单 DP 求出.
79D Password
考虑原序列的差分序列,题意转化为:每次改变 和 的状态,将有 个 的序列变成全 的.
首先可以通过 次最短路计算出改变任意两个位置状态的代价.由于边权为 ,01 bfs 即可.
然后就直接设 表示将 内的位置全变成 的最小代价,枚举仍不是 的位置,转移即可.
1796D Maximum Subarray
贪不动,尝试 DP.
先将所有 减去 ,问题转化为要将原序列中某些位置加上 ,最大化最大子段和.
考虑设 表示在 处结束的子段,加了 次的最大和.
转移需要考虑当前点改不改,由于我们可以在 之后的某些位置操作,所以取答案时,需要对所有满足 的 取 .
注意不要转移到非法状态.注意不要转移到非法状态.注意不要转移到非法状态.
1764E Doremy’s Number Line
若 ,那么可以直接涂掉;若 ,那么不可能涂掉.我们只需要解决 的情况.
显然要拿出来涂 ,所以先踢掉它.事实上,我们只需要判定抛开 后,剩下的操作能涂到的最大位置是否 即可.
不妨设 ,分类讨论其对能取到的最大右端点 的贡献.
- 不由 取到,此时其他点都可以任意被涂了,所以 .
- 由 取到,此时 可以扩展剩余 个位置取到的最大值 .
那么按照 排序后取一遍 即可.
1817D Toy Machine
容易 通过瞎摁 观察到,当 时,可以通过 次 加上一次 将 转到最左边.
考虑 时怎么做,我们可以通过镜像上面的操作将目标点转到右上角,然后重复最多 次 将所有的块堆到右上角,此时进行 操作就转化成了 的情况,直接做即可.
1852A Ntarsis’ Set
考虑二分最大的 ,使得 都能在 轮操作之后被删掉,答案显然就是 .
判定答案时,我们不妨换一下对删数操作的定义.若当前数的排名是 ,我们直接将删数操作定义为 .按照这个定义在没有被删除的元素上操作的结果和原定义是吻合的,而在被删除的元素上则带来了一些比原定义更好的性质.若存在某个 ,我们考察进行这个操作后会发生什么:
- 中的元素被删空,此时 ,即本次删了一个前缀,操作一次之后 ,正好对应删空.
- 中的元素未被删空,此时 ,操作后 ,正好对应没删空.
那么判定就直接暴力进行 轮操作,判定 即可.
1852B Imbalanced Arrays
首先观察到,如果同时存在 ,那么一定无解,因为这要求 且 ,显然矛盾.
考虑 ,那么 只可能填 或 ,具体填哪个取决于 的符号.又由于 ,且不存在 ,也就是说 构成一个长度为 的排列,所以如果 中同时不存在 或 ,那么也无解.
于是我们可以这样构造:从大到小分配 ,每次找到 或 ,设当前最大没有分配的数为 ,若 ,则 ,否则 .
显然可以在对 排序后利用双指针优化.
1852C Ina of the Mountain
即模 意义下全都变成 .如果不模 ,这不是我们积木大赛吗!若记 ,那么答案就是 .
模 可以看做预先给 某些位置加 ,反映在差分数组上就是选择若干个二元组 ,其中 ,然后给 加 ,给 减 .
于是问题转化为进行任意次上述操作,最小化 .
显然我们不会对一个正数加,也不会对一个负数减.于是我们可以从前往后考虑,每遇到正数,就找前面第一个没有使用过的、最小的负数,若使用后更优就直接用.由于放着最小值不用没有收益,所以正确性显然.
1848C Vika and Price Tags
考虑 的情况,不妨设 ,然后就可以观察到如果已经达到了目标状态,即 ,那么接下来进行的操作就会形如
周期为 .
那么只需要算出每个位置上的数对达到目标状态的次数,然后判定 下是否相等即可.
考虑快速计算操作次数,不妨设 ,,状态变化形如
周期也为 ,且每轮中 会减 .由于我们只关心操作次数 后的值,所以模拟操作时可以直接将 模 .然后讨论一下
- 时,,使用 步操作转化为子问题,递归解决 .
- 时,直接递归解决 .
时类似.每次子问题规模至少减半,那么复杂度 ,其中 是值域.
1848D Vika and Bonuses
容易发现个位数 是一轮循环,且经过一轮循环之后 会增加 .
考虑对一个 求解.设循环轮数为 ,由于我们一定先给 增再累计,所以操作后的值 ,是一个关于 的二次函数,容易求出极值.然后对每个可能的 做一遍就行了.
记得判掉 和 .
1848E Vika and Stone Skipping
设 ,即以某个力 丢出石子后,第 次接触水面在 处.
- 若 是偶数,那么 ,由于有 ,所以 .
- 若 是奇数,那么 ,此时有 .
所以 的每个奇因子 都唯一对应一个 ,也唯一对应一个 ,对答案贡献恰好 .那么问题转化为快速计算 的奇因子数目.考虑 的唯一分解 ,那么答案就是 .
由于直接维护会涉及逆元操作,而模数不是大质数,逆元不一定总存在,那么直接使用大炮打蚊子,拿个线段树维护.
1848F Vika and Wiki
打个表先. 次操作后, 位置上的数会被异或到 位置的次数是 .
那么,第 次操作后, 会变成 .注意到操作 次后会变成 ,也就是说肯定存在解.
那么直接考虑从高位到低位确定答案,能填 就填 .
712D Memory and Scores
设 表示进行了 轮,分数差为 时的局面数.
然而这样直接转移的话会带个诡异系数,不是很好优化,考虑直接玩 轮,每一轮只有一个人操作,那么有 ,其中 .
1846E Rudolf and Snowflakes
即确定是否存在 和 满足 ,其中 .
考虑等比求和公式,上式等于 .顶上那个指数的可能数量是 级别的,于是考虑枚举 ,二分 ,最后检验是否合法就行.
注意精度和炸 long long
.
1841E Fill the Matrix
显然我们的策略是每次找到最长的横线填数,设长度为 ,那么贡献就是 .
考虑计算每种不同长度横线的个数,考虑一个位置 ,能作为以 为右端点的横线的左端点只能是 这段前缀中的后缀最大值,这个可以单调栈维护,然后在弹栈的时候记录一下前驱,就可以算数量了.
1840G1 In Search of Truth (Easy Version)
即构造一个长度 的序列 ,使得 .
考虑光速幂的构造,设置块长 ,显然有 .那么前面丢 个 ,后面丢 个 .显然 时最优.
1839D Ball Sorting
我们的策略是选出一个上升子序列,这个上升子序列将原序列划分成了若干部分,然后每个部分放一个白球,进行消除.
于是设 表示考虑了 这个前缀, 在上升子序列里,被划分出了 部分,上升子序列的最长长度.
若 ,那么可以直接继承 .否则直接转移.
注意答案要做前缀 .
1837E Playoff Fixing
考虑从最上面开始往下推.设最上面为第一层.
考虑安排第 层,此时第 层已经安排完毕,故只有新增的 个人的位置需要确定,若未钦定任何位置,那么答案需要乘上 ,前面那个因子是在考虑新加入的人的排列,后面那个因子是在考虑新加入的人在某场比赛中的先后.
现在某些位置已经确定了,也就是确定了某些人的排列和某些场次的先后,那么减去即可.
735E Ostap and Tree
设 表示 子树中,存在一个黑点与 之间的距离为 ,且距离大于 的点的限制均被满足的方案数.
考虑合并 这棵子树,枚举 ,转移如下:
- 若 ,那么两条路径直接拼接不会导致有点不被满足,那么直接 .
- 若 ,不妨设 、 子树中达到 、 限制的点分别为 、,那么 这条链上一定存在某些节点不被满足,此时有 .
答案即为 .
1348F Phoenix and Memory
首先考虑求出一个排列.若存在不止一个满足条件的排列,那么其他排列一定可以通过交换求出的排列中的某两项来求出.
贪个心先,将线段按照左端点升序排序,考虑按照升序确定 这些值所填的位置,每次取出能够覆盖到 的,右端点最小的区间,将 放到对应的位置上.由于题目保证有解,这样的构造显然合法.
然后就是确定能否交换两个位置了.设位置 和 可以交换,那么有:,考虑按照 升序添加元素干掉第一个限制,然后第二个限制相当于看有没有区间覆盖到 ,拿一棵线段树维护区间覆盖单点查询即可.
1832E Combinatorics Problem
扰动一下:
递推即可.
1830B The BOSS Can Count Pairs
考虑 ,那么考虑根号分治.
枚举 ,不妨设 ,那么有 ,拿个桶计数就行了. 时由于钦定 ,需要单独拿出来扫一遍.
1515E Phoenix and Computers
设 表示已经打开了 台电脑,已经打开的电脑构成了 个连续段的方案数.
考虑对连续段操作:
-
延长连续段.可以选择在某个连续段两边插入,或间隔一个插入,第二种操作会导致中间的那个未被打开的电脑被打开,有 ,,
-
合并连续段.间隔两个格子的连续段可以通过任意打开一台电脑来合并,有 ;间隔三个格子的连续段可以通过打开中间的一台电脑合并,有 .
-
新建连续段..
1228E Another Filling the Grid
设 表示恰有 行 列最小值为 的方案, 表示钦定 行 列,使得剩下的行列最小值不为 的方案数,有
其中 显然为 .
可以直接计算.
1120C Compress String
设 表示考虑了前 个字符的最小代价,有转移
其中 满足 是 的子串.
这样决策点很难找,不妨直接枚举子串的结束位置 ,设 表示前缀 和 的最长公共后缀,有转移 .这样就能做到 转移了.
1499F Diameter Cuts
设 表示 的子树内,以 开始的链最长的长度为 的方案数.
转移考虑合并一棵子树 ,枚举 中最长链的长度 ,有
- 时,此时可以选择不断开边 ,也可选择断开 ,有转移 .
- 时,此时只能选择断开 ,有转移 .
看似是 的,但事实上若枚举上界定为子树深度,那么可以分析出时间复杂度为 .分析参考 这篇博客.
1819B The Butcher
首先可以找到最大的长和宽,这可能是原长方形的或宽.
然后可以算面积和,就可以初步判定长宽的合法性.
考虑如何确定某个长宽是合法的.考虑模拟,每次选出最长的长或宽尝试去剪,若某次选不出来就寄了.可以用两个 multiset
维护.
1817B Fish Graph
将环上外挂两个节点的节点称作关键节点,显然关键节点的度数 .
考虑枚举关键节点 ,我们只需要搜出一个过 的最小简单环就能直接构造.
如何搜最小简单环?考虑以 为根的 bfs 树,若 bfs 过程中访问到了一条横叉边 ,满足 和 在 的不同子树内,那么 显然是一个合法的简单环,而 bfs 过程中访问到的第一个这样的横叉边构成的环显然是最小的.记录 bfs 树上的父边就能还原方案.
1811G Vlad and the Nice Paths
先考虑如何求出最长长度.
设 表示以 结束的好路径的最长长度是多少,转移枚举之前的位置 ,其中 满足区间 中 出现的次数 .
考虑如何计数,设区间 中 的出现次数为 ,由于钦定选 ,那么次数的贡献系数就是 .
1870D Prefix Purchase
考虑选择序列中价格最小的位置 ,然后买 次,这样显然给出了操作完后 可能的最大值.
接下来考虑在不动 的情况下调整使得字典序最大.设上次调整完后剩余的钱数为 ,上次买的位置是 ,我们找到 中的最小值 ,然后卖掉 个 后加钱买个数相等的 ,这样显然不会改变 的值,由于 在 后边,所以会增大字典序.由于每次选的是后缀最小值,所以调整过程一定能结束.
此时已经可以利用优先队列做到 ,但是注意到每次选的是最靠后的后缀最小值,可以直接预处理做到 .
1864F Exotic Queries
先考虑没有区间询问怎么做.
若我们每次都能将等于某个值的所有数归 ,那么答案就是值域区间中值的个数,容易证明这是答案的下界.
考虑将我们未考虑到的操作次数加上去.考虑一个值在序列中所有的出现位置,若相邻位置之间的最大值小于当前值,那么当前值需要的归零次数需要增加一次.统计答案就是统计这样的点对数目.
考虑带上区间询问怎么做.考虑将询问挂右端点上扫描线,需要统计的点对 需要满足
由于总点对数目是 的,弄个树状数组维护单点加后缀和,然后暴力加点即可.
当然还需要一棵线段树维护单点赋值区间 .
1863F Divide, XOR, and Conquer
考察一个区间 在何时可以被划分出并保留 .
记 .对于一个划分点 ,记 .
- 若 ,那么对于任意的划分点 ,一定有 ,也就是说可以随便划分.
- 若 时,考虑 的最高位 ,对于一个划分点 , 和 的第 位一定不同,且高于 的位数一定相同.也就是说,第 位决定了 和 的大小关系.
那么我们按照区间长度降序遍历所有区间,记 表示考察 开始的合法区间,每个合法区间的异或和的最高位在 中的对应位都是 .也就是说,对于 中的每一位 ,若该位上为 ,那么存在一个合法区间 ,使得 的最高位为 .
当我们枚举一个区间 时,我们只需判断 是否有值,若有值则 可以被某个区间划分出来.
保留右半边的情况类似.
1863E Speedrun
容易发现,若我们第一天的开始时间已经确定了,那么整个流程都是确定的,我们只需要决策第一天有多少活动需要推迟一天完成即可.
尝试设 表示 这个活动不推迟 / 推迟一天完成时,依赖 的事件的最晚完成时间.为了完成后继事件 到 的转移,我们需要判定 推迟一天后是否会影响到 的完成.如果影响了,则需要从 转移.
麻烦之处在于, 这条边造成的时间限制不一定是紧的,也就是说 可能需要在 完成后推迟很久才能被完成,此时尝试推迟 的完成不会对 的完成造成影响.
我们可以先尝试钦定顺序做这些活动,给每个节点先钦定一个完成日期,若 的前驱 的完成时刻晚于 ,那么 需要推迟一天.然后这样就可以快速计算推迟造成的影响了,而由于我们按照逆拓扑序进行 DP,所以推迟不会对后面递推到的点造成影响,无后效性.
1854C Expected Destruction
若集合是可重的,那么答案就是 .考虑去掉由于插入重复数字导致集合元素减少对期望造成的贡献.
发现只有原序列中相邻的元素才可能造成这样的贡献,于是考虑枚举这样的元素对,除去贡献.
考虑 的时候,直接设 表示 加了 次, 加了 次,转移显然.当 和 的差值等于 时,就直接贡献到答案上.
1822G Magic Triples
枚举 ,再枚举 , 和 分别能取 ,拿个桶统计即可.
然而这样做的时间复杂度是 的,直接做就寄了.由于有 ,那么 .
考虑根号分治,设置阈值 .
- 当 的时候直接做,这部分复杂度是 .
- 当 时,有用的因数不超过 个,直接枚举因数,这部分复杂度是 .
显然 取 时达到平衡,复杂度 ,可以通过.
1707C DFS Trees
由于边权互不相同,原图的 MST 确定,直接弄出来.
题目中给的那个伪代码就是会找到原图的一个 dfs 树,想到 dfs 树合法的条件就是不存在横叉边,若当 MST 的根确定为 时,存在作为横叉边的非树边,那么 一定不合法.
这个判定条件是充要的,由于我们找到的是 MST,所以任意一条非树边 加入后构成的环中, 的边权一定是最大的,那么无论走到 或 中的哪一个点,都不会先走 .
首先随便钦定一个根,然后依次考虑所有非树边 .
- 若 是 的祖先或 是 的祖先,那么这条链上除开 和 的点都要被日掉.
- 不然,除了 和 子树内的点都要被日掉.
树上差分打标记即可.
1375G Tree Modification
由于树是一个二分图,考虑将这个二分图的两个部分染成黑白两色.如果我们对 进行一次操作,不妨假设操作前 是白色, 是黑色,那么由于操作后 连到了 上,其颜色改变,其他节点颜色不变.
考虑对菊花图染色,发现其中有一种颜色只有一个节点,设原树上白色节点数为 ,黑色节点数目为 ,答案即为 .
以后遇到树上诡异操作可以尝试染色后观察性质.
1870E Another MEX Problem
容易设计一个 2D / 1D 的动态规划:设 为考虑前 个元素,划分出的段的 mex 的异或和为 的方案是否存在.这个 DP 从状态到转移都难以优化,于是我们考察有用的转移的数量.
容易发现,对于以当前位置为右端点且 mex 相同的所有区间,只有最短的那个是有用的,因为可以不选,转移区间变小必定不劣.
然后感受一下这个数量级,发现总数是 的.证明见 官方题解.
1870F Lazy Numbers
考虑将所有数的 进制表示插到 Trie 里面,这棵 Trie 会长成什么样.
发现一个节点的 bfs 序对应的就是自己的编号,而 dfs 序对应的是字典序 自己的数字数量.
考虑逐层计算满足条件的节点的数量,然后发现同层 bfs 序从左到右,每次增量只有 ,而 dfs 序增量 ,也就是说可以二分一层中合法节点的左端点和右端点.
复杂度 .
1810E Monsters
点权转边权,将边的权值设为两边点权的较大值.限制转化为走过的节点数大于边权才能经过这条边.
这是一个瓶颈路的模型,故考虑建出 Kruskal 重构树,限制转化为子树大小 父亲的权值就能往父亲走,问最终能不能走到根.
dfs 一遍即可.
1834E MEX of LCM
由于 LCM 会比较离散,所以 mex 不会很大,猜测是 级别.
考虑以一个位置为左端点的所有区间的 LCM,发现每次变大至少增加一个 的因子,也就是说有用的右端点是 级别的.
那么考虑从左往右扫,维护一个右端点到所有左端点的 LCM,超过范围直接丢弃.然后暴力即可.
1817C Similar Polynomials
考虑两边取 阶差分.
设 做 阶差分后得到的函数是 ,左边点值差分得到 ,右边得到 .然后就可以计算 .
1830C Hyperregular Bracket Strings
对于一个长度为 的序列,没有任何限制时答案就是 Catalan 数 .
当两个限制的区间相交时,可以把交区间拆出来,然后就变成了三个独立的部分,方案相乘.
当两个限制的区间包含时,不妨设两区间为 和 ,令 ,发现区间 和区间 都要是合法括号序列,且方案独立.
进一步地,我们发现,若令 表示覆盖到 的区间集合,则对于 相同的所有位置,构成的子序列必须要是合法括号序列,且对于 不同的位置,方案独立.
哈希储存 即可计算.
gym104651A Almost Prefix Concatenation
考虑贡献里的平方项怎么处理,由于 ,那么我们可以记 表示考虑到了 ,所有划分方案 的和, 表示 的和, 表示方案个数,有转移:
其中 满足 这一段是个 Almost Prefix.
更新范围可以两次二分 LCP 求得,然后就可以直接上线段树优化 DP.
gym104651B Palindromic Beads
考虑从内往外拼回文路径,由于每种颜色只出现两次,对于最终选出的回文串,从内往外的同颜色点对,点之间的距离一定递增.
于是将点对按照两点间的距离升序排序,转移考虑将当前点对拼接到之前的某个回文串两边,能够转移的条件是之前最后拼接的点对在树上的路径是当前点对对应路径的子路径.
考虑点对 对应路径何时是点对 对应路径的子路径,先给树随便定个根:
-
的 LCA 不是 中任意一个时, 的限制是有一个在 的子树中,另外一个在 的子树中.
-
的 LCA 是 中某个时,不妨设是 ,令 是 路径上 的下一个点, 的限制是有一个在 的子树中,另外一个不在 的子树中.
发现限制是 个矩形,直接树套树优化 DP,需要支持矩形取 ,单点查询.
1888D Dances
巨大垃圾做法.
考虑一个二分图建模,左部的 往右部所有满足 的 建边,答案就是 减去最大匹配数.
直接建图做显然 T 飞了,考虑应用 Hall 定理,答案实际上就是
离散化之后维护每个 处 中的值就行,需要支持前缀加全局 .
对于多个 怎么求?注意到答案只有 段,直接算即可.
1888F Minimum Array
由于是求字典序最小的数组,于是考虑逐位确定是什么.我们维护每个时刻第 位上应该是什么,然后贪心选择 ,把不是 的位置 ban 掉,然后再考虑下一位,已经被 ban 的位置不考虑.
然后发现每个位置只会被 ban 一次,在线段树上暴力做即可.
1827D Two Centroids
一棵树有两个重心的条件是节点数量为偶数,且存在一条边将整棵树分成节点数量相同的两部分.
假如我们当前钦定了一个重心 ,设以 为根时最大的子树大小为 ,此时的答案就是 .
那么问题转化为加点,维护 .问 ckain 手玩一下发现 一定会取在原树重心,证明可以考虑调整法.
然后关于树的重心有一个经典结论,若往当前重心 的子树中加点,那么重心要么不变,要么往被加到的子树中移动一条边.把树拍到 dfn 序上维护当前子树大小即可.
1889B Doremy’s Connecting Plan
容易发现那个 没用,因为我们可以给所有 除 .
若当前存在 和 可以建边,满足 ,设 所在连通块权值和为 , 所在联通块大小为 ,那么我们有
这说明 和 中至少有一个成立,不妨设 ,可以发现此时将 和 建边也是合法的.这说明我们会进行的操作实际上只有将某个点和 建边.
那么直接按照 的大小贪心地连即可,出现矛盾即不存在方案.
1889C Doremy’s Drying Plan
注意到 很小,也就是说被太多线段覆盖住的位置是没救的,这启发我们去考虑一个和覆盖当前位置的线段数有关的做法.
我们相当于选取若干个位置,然后移除所有覆盖了这些位置的线段.考虑使用 DP 去刻画这一过程,设 为钦定 选择,此时需要移除 条线段时,最多能选择多少个位置.转移考虑枚举上一个被选择的位置 ,此时包含 的线段已经全被移除,为了选择 ,我们需要再移除所有包含 且不包含 的线段,即对满足 的 计数.由于覆盖 位置的线段只有 条,这一计数可以暴力完成.此时复杂度为 .
状态数看起来已经不能优化了,考虑优化转移.此时可以发现,由于只有 条线段覆盖了 ,我们可以按照所有覆盖 的线段的左端点将 划分成 段,其中每一段的转移是相同的.拿线段树维护即可做到 .
1895D XOR Construction
首先对序列做异或前缀和,得到的序列即钦定 时满足条件 2 的序列,我们要做的就是钦定一个合适的 ,使得最终序列构成一个排列.
当钦定 时,我们所做的操作就相当于给 的每一位异或上 .而题目保证答案存在,也就是说异或某个 后得到的序列中的元素应当互不相同,即我们只需满足最大值 即可.
异或某个数的最大值,可以使用 01-Trie 解决.
1895E Infinite Card Game
由于每一张牌被击退之后都会回到自己的牌堆,所以总局面数实际上是相当少的,只需考虑当前某人出了某张牌之后,对方的决策即可.
实际上这个决策是确定的!若对面出了一张防御力为 的牌,为了击败他,我们应当选择一张攻击力大于 的牌了;为了为难对面,我们应当选择防御力尽可能大的牌.所以我们一定会选择攻击力大于 的牌中,防御力最大的那一张,这个可以双指针解决.当然,若选不出来就输了.
把每张牌往对面在我们出这张牌的情况下会出的牌连边,显然每个点只会有 条出边,构成一个内向基环树森林.如果能够走到环显然是平局,否则看在哪个人的手牌处停下即可.
使用记忆化搜索实现.
1895F Fancy Arrays
直接计数显然是不好做的,考虑对第一个条件容斥,用最小值在 里的路径个数减去最大值在 里的路径个数即可.
考虑解决第一部分:我们可以先对路径的“形状”(即差分数组)计数,由于每个位置的取值为 ,所以“形状”的个数为 ;然后再钦定每条路径最小值的取值,这部分方案有 种.故这部分方案数是:.
第二部分是简单 DP,矩阵快速幂优化即可.
1861E Non-Intersecting Subpermutations
首先观察到,对于一个特定的序列,我们可以贪心地去计算划分数,能划分就划分,不会影响答案.
于是考虑设 表示考虑了前 位,目前无重复数字的后缀长度为 的序列个数.
每个满足要求的子串对答案的贡献为 ,故答案为
考虑 的转移:
- 考虑在长度为 的后缀后添加一个在该后缀中没有出现过的数字,转移有两种类型
- 上次未凑出完整的无重复数字的子串:.
- 上次凑出来了:.
- 如果添加了一个出现过的数字,由于我们考虑的是所有序列,所以会从后缀长度 的所有状态转移一次:,.
显然可以使用前缀和优化.
1835D Doctor’s Brown Hypothesis
容易发现只有在一个 SCC 里的点对才可能成为答案,故考虑逐 SCC 求解答案.
的条件说明了我们可以使用图中的所有环来对某条路径增广,而根据裴蜀定理,设所有环长的 gcd 为 ,我们可以凑出足够长且长度为 的倍数的路径.
考虑如何求解 ,考虑拉出原图中的一棵外向生成树,令根为 ,设 表示树上根到点 的距离.对于一条边 ,考虑树上 到 的路径,长度为 ,由于环长 ,一定还存在一条 的路径,长度模 同余 ,将其拼接上树上 的路径,得到一条长度模 同余 的路径,这条路径再拼接上 这条边,得到了一个环,长度模 同余 ,故 .那么考虑原图中的所有边 , 的 gcd 即为要求的 .
显然只有 ,或 为偶数且 时有解,开个桶计数即可.