[BZOJ4310] 跳蚤 SAM || SA】的更多相关文章

没有代码的. 传送门 先二分出第 \(mid\) 大的字串 \(s\),然后从后往前切割,每次大于 \(s\) 了就不行. 涉及到的操作:求第 \(mid\) 大子串:比较两个字串(求 \(lcp\)). SAM:\(mid\) 大子串随便求.求 \(lcp\)? 二分+字符串哈希?莫名其妙多个 \(log\),而且字符串哈希以前没实现过啊QAQ 再建一个反串SAM在parent树上求LCA?太麻烦了吧..而且用RMQ \(O(1)\) 求LCA也没实现过啊QAQ SA:感觉挺好的,求第 \(m…
[BZOJ4310] 跳蚤 Description 首先,他会把串分成不超过 \(k\) 个子串,然后对于每个子串 \(S\) ,他会从 \(S\) 的所有子串中选择字典序最大的那一个,并在选出来的 \(k\) 个子串中选择字典序最大的那一个.他称其为"魔力串".现在他想找一个最优的分法让"魔力串"字典序最小. Solution 我们将某个子串在所有子串(本质不同)中按照字典序的排名称作它的字典序排名.思考如何使用后缀数组快速求出一个子串的字典序排名. 假设我们要求…
原文链接https://www.cnblogs.com/zhouzhendong/p/9256033.html 题目传送门 - CF873F 题意 给定长度为 $n$ 的字符串 $s$,以及给定这个字符串每一个位置是否 “禁止结尾” 的信息. 一个字符串 $a$ 的价值为 $|a|\times f(a)$ . 其中 $f(a)$为 $a$ 在 $s$ 中的匹配次数(如果匹配的结尾为禁止结尾点,那么不算匹配成功) 问在所有的字符串 $a$ 中,$\max(|a|\times f(a)$ 的值. $…
Description 很久很久以前,森林里住着一群跳蚤.一天,跳蚤国王得到了一个神秘的字符串,它想进行研究.首先,他会把串 分成不超过 k 个子串,然后对于每个子串 S,他会从S的所有子串中选择字典序最大的那一个,并在选出来的k个子串中选择字典序最大的那一个.他称其为"魔力串".现在他想找一个最优的分法让"魔力串"字典序最小. Input 第一行一个整数 k,K<=15 接下来一个长度不超过 10^5 的字符串 S. Output 输出一行,表示字典序最小的…
注意到答案一定是原串的子串,于是考虑造出SA,二分答案是第几小的子串.第k小子串很容易在SA上求出.之后计算使他成为最大子串至少要在几个位置切割,对每个字典序比答案大的后缀,找到所有合法切割位置(求lcp即可),就转化成了选最少的点使每个区间都包含至少一个点的经典问题. #include<iostream> #include<cstdio> #include<cmath> #include<cstdlib> #include<cstring> #…
SAM里的转台不会有重复串,所以答案就是每个right集合所代表的串个数的和 #include<iostream> #include<cstdio> #include<cstring> using namespace std; const int N=100005; int T,n,fa[N],ch[N][27],dis[N],cur=1,con=1,la; long long ans; char s[N]; void ins(int c,int id) { la=cu…
首先求出后缀数组,得到本质不同的子串的个数. 然后二分答案,每次先通过后缀数组求出第$mid$小的子串,然后贪心进行检验. 检验的时候,从后往前贪心,每次加入一个后缀,如果不能加了,那就划为一段. 时间复杂度$O(n\log n)$. #include<cstdio> #include<cstring> #include<algorithm> #define N 100010 using namespace std; typedef long long ll; char…
算法介绍见:http://www.cnblogs.com/Sakits/p/8232402.html 广义SAM资料:https://www.cnblogs.com/phile/p/4511571.html [例题] 参考http://www.cnblogs.com/Candyouth/p/5368750.html 1.洛谷P3804[模板]后缀自动机 因为$Parent$树上的叶子节点有可能变成一个父亲节点,所以可能某个叶子节点$r_i$不存在,比如$aa$,$r_i=1$的就不存在,它从一个…
2018清华冬令营 又一次由于接连而至的玄学现象跪惨,错失良机,就不再公开提我这次惨痛的经历了,写点干货-- day1 A 零食 (1s, 1G) 试题简述 \(n\) 种物品1,\(m\) 种物品2,要求安排一个两种物品的排列,当且仅当某个物品的有前一个物品前一个物品种类和它一样时才能让总和增加这个物品的权值. 现给出所有物品的权值,求最大总和. 输入 第一行一个整数 \(T\),表示数据组数. 第二行一个正整数 \(n\),表示物品1的个数. 第三行 \(n\) 个整数,\(A_1, A_2…
目录 hdu6599题意: manacher+后缀自动机+倍增 \(O(nlog(n))\) manacher+后缀数组+二分 \(O(nlog(n))\) 回文树(回文自动机) \(O(n)\) @(hdu6599:求本质不同的回文串长度及数量) 欢迎交流 hdu6599题意: 传送门: here 求有多少个回文串的前\(⌈ \frac {len}{2} ⌉\)个字符也是回文串.(两组解可重复) 将这些回文串按长度分类,分别输出长度为\(1,2,...,n\)的合法串的数量. 前期分析: 首先…