08 2017 档案
摘要:用SAM支持往末尾在线添加字符的功能。 设表示右端点为i的每个左端点的答案,那么当变为时,在SAM的parent链形成的树中会新增一个叶子。 对于每个节点,维护它最后一次出现的位置的右端点,那么加入的时候,需要把它到根路径上所有节点的都改为$
阅读全文
摘要:首先通过DFS序将原问题转化为序列上区间加、询问区间kth的问题。 考虑分块,设块大小为,每块维护排序过后的。 对于修改,整块的部分可以直接打标记,而零碎的两块因为本来有序,故可以按照修改区间将其分离成两个有序序列(不在修改区间)和(在修改区间)。 对
阅读全文
摘要:不难发现题中过程对应着动态维护关于的最大生成树。 为了让最大,同时让字典序最大,那么最后得到的一定是按排序的最大生成树。 对于每条非树边,那么它要早于树上到路径上任意一条同值的边出现。 而非树边之间显然不存在限制关系,因此非
阅读全文
摘要:维护一个保护集合,表示哪些点可能胜利。 首先将所有绿点加入。 对于一个不在的点,若它存在某个后继在中,则将其加入。 对于一个不在的点,若它所有后继都在中,则将其加入。 通过拓扑可以求出集合,那么剩
阅读全文
摘要:枚举子串的中心,往两侧扩展,将两侧对应位置的字符交替写下来,得到一个字符串。 若前后长度为的子串循环同构,则在中它们对应长度为的前缀,需要满足它可以由不超过个偶回文串拼接而成。 有一个结论是,若,其中都是偶回文串,那么要么是的最长偶回文
阅读全文
摘要:把看作,看作,设为前缀和,则相当于找两个位置使得,且是的区间最大值。 求出询问区间的最大值,然后找到在该区间内最左和最右的出现位置,将其作为答案。 那么剩下的答案只可能在或$(o,r]
阅读全文
摘要:线段树维护每个点的最有可能是答案的数以及它的权重。 合并两个节点的时候,将权重互相抵消,保留较大的那一个。 得到答案后,再在对应权值的Treap中查询出现次数,检查是否真正是答案。 时间复杂度。
阅读全文