对所有询问串建立AC自动机. 然后将母串在AC自动机上跑,每走到一个点x,从x点出发沿着fail指针能到的所有前缀都是匹配成功的,暴力向上走,碰到走过的就break,这样每个点最多只会被标记一次. 时间复杂度$O(N+100M)$. #include<cstdio> #include<cstring> const int N=10000003,M=100010; int tot,son[N][4],f[N],fail[N],q[N];bool v[N]; int n,m,i,fin…
SAM裸题.这道题卡空间.要小心数组别开炸了. #include<cstdio> #include<cstring> typedef long long ll; const int maxn = 2e7+20; int par[maxn],mx[maxn],tr[maxn][4]; int cnt=1,last=1; inline int change (char ch) { if(ch=='E') return 0; else if(ch=='S') return 1; else…