BZOJ5084[hashit]】的更多相关文章

题解: 后缀自动机 我们可以通过建立trie 把询问变成询问一些点的并 把trie建立成SAM和广义SAM基本相同,就是在父亲和儿子之间连边 然后就变成了询问树链的并 我们可以发现答案=sigma dis[i]  -sigma(dis[lca(i,i+1)]) 其中i和i+1dfs序相邻 可以通过set来维护 *** 把倍增的预处理写在了dfs前 把&&写成了& 代码: #include <bits/stdc++.h> #define rint register int…
做得心 力 憔 悴 Description 你有一个字符串S,一开始为空串,要求支持两种操作 在S后面加入字母C 删除S最后一个字母 问每次操作后S有多少个两两不同的连续子串 Input 一行一个字符串Q,表示对S的操作 如果第i个字母是小写字母c,表示第一种加字母c的操作 如果为-表示删除操作,保证所有删除操作前S都非空 |Q|<=10^5 Output 输出|Q|行,第i行表示i个操作之后S内有多少个不同子串 题目分析 陈老师神题x2,暂时只会做法一. 做法一:暴力回退 还是自己菜啊……这么…
题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=5084 题解 考虑平常对于静态问题,我们应该如何用 SAM 求本质不同的子串个数. 对于一个常规的 SAM,这个东西应该是 \(\sum\limits_{i\in V} len_i - len_{fa_i}\). 很容易发现,我们如果把这个字符串每一个时刻的前一个字符和后一个字符给连接起来,这是一个树的关系. 考虑对这个树建立一棵广义 SAM. 但是上面的结论在广义 SAM 中不适用.不适用的…
赛前任务 tags:任务清单 前言 现在xzy太弱了,而且他最近越来越弱了,天天被爆踩,天天被爆踩 题单不会在作业部落发布,所以可(yi)能(ding)会不及时更新 省选前的练习莫名其妙地成为了Noip前的杂题训练,我也很无奈啊 做完了的扔最后,欢迎好题推荐 这么多题肯定是完不成了,能多做一道是一道吧 DP yyb真是强得不要不要的辣:http://www.cnblogs.com/cjyyb/category/1036536.html [ ] [SDOI2010]地精部落 https://www…
“写sam是肯定会去写的,这样才学的了字符串,后缀数组又不会用 >ω<, sam套上数据结构的感觉就像回家一样! 里面又能剖分又能线段树合并,调试又好调,我爱死这种写法了 !qwq” SAM是一个DFA,它存储了某字符串的所有子串信息. 待更. 博主水平不行,尽量在退役前多更些. 插入字符: void extend(int id,int&now) { int p=now; ) { now=ch[p][id]; return; } int np=++tot; len[np]=len[p]…
题目描述 你有一个字符串S,一开始为空串,要求支持两种操作 在S后面加入字母C 删除S最后一个字母 问每次操作后S有多少个两两不同的连续子串 输入 一行一个字符串Q,表示对S的操作 如果第i个字母是小写字母c,表示第一种加字母c的操作 如果为-表示删除操作,保证所有删除操作前S都非空 |Q|<=10^5 输出 输出|Q|行,第i行表示i个操作之后S内有多少个不同子串 样例输入 aba-caba 样例输出 135 3 6 91217 题解 广义后缀自动机+树链的并+STL-set 题目给出的字符串…
题面 传送门 题解 后缀平衡树是个啥啊我不会啊-- 那么我们来考虑一下\(SAM\)的做法好了 不难发现它的本义是要我们维护一棵\(trie\)树,并求出\(trie\)树上每一个节点到根的这段串的不同子串个数,而显然一个串的不同子串个数就是它的\(SAM\)上每一个节点的\(len[p]-len[fa[p]]\)之和 那么我们对这个\(trie\)建一个广义\(SAM\),这个\(SAM\)一定包含每一个路径的\(SAM\) 我们对每一个这棵\(trie\)上的每一个节点记录一个\(pos\)…
点此看题面 大致题意: 每次在字符串后面加入或删除一个字符,求本质不同的子串个数. 后缀自动机 先说明,此题后缀自动机的确能过. 但我的后缀自动机比较弱,遇上一个较强的\(Hack\)数据就被卡掉了...(可见这场比赛的\(T1\):[HHHOJ]ZJOI2019模拟赛(十三)03.10) 尽管如此,还是讲一下大致思路吧. 更新答案 考虑后缀自动机求解本质不同的子串个数时,我们需要统计\(Len_x-Len_{fa_x}\). 所以我们可以简单定义一个\(F5\)函数来刷新答案: #define…
Description 你有一个字符串S,一开始为空串,要求支持两种操作 在S后面加入字母C 删除S最后一个字母 问每次操作后S有多少个两两不同的连续子串 Solution 先忽略删除操作,建出最终的串的 \(SAM\),构建过程的所有可能的串的 \(SAM\) 都包括在这里面 要维护 \(\sum len[x]-len[fa[x]]\) 考虑插入一个结点会产生的贡献,因为每一条边只会贡献一次,所以需要容斥减掉一些贡献 那么需要考虑已经被加入的结点中与这个点 \(dfs\) 序相邻的,他们的 \…
比较考验对后缀自动机构建过程的理解. 之前看题解写的都是树链的并,但是想了想好像可以直接撤销,复杂度是线性的. 自己想出来的,感觉后缀自动机的题应该不太能难倒我~ 注意:一定要手画一下后缀自动机的构建过程,然后看着自己画的图一步一步模拟即可. Code: #include <stack> #include <cstdio> #include <cstring> #include <algorithm> #define N 200003 #define ll…