又学会了一种字符串匹配 + 骗分技巧!!!
用
b
i
t
s
e
t
bitset
bitset 也可以字符串匹配!!!
考虑询问的字符串的总长度只有
1
0
5
10^5
105,所以可以考虑
n
2
ω
\frac{n^2}{\omega}
ωn2 的做法
考虑从前往后遍历查询字符串,然后只要把之前匹配的结果往后移一位,然后
&
\&
& 当前字符的出现位置即可
时间复杂度
O
(
n
2
ω
)
O(\frac{n^2}{\omega})
O(ωn2)
有些边界情况需要特判
#include
using namespace std;
const int N=100100;
char str[N],y[N];
bitset<N> bs[26];
int main(){
scanf("%s",str+1);
int n=strlen(str+1);
for(int i=1;i<=n;i++) bs[str[i]-'a'][i]=1;
int q;scanf("%d",&q);
while(q--){
int op,x;scanf("%d%d",&op,&x);
if(op==1){
scanf("%s",y);
bs[str[x]-'a'][x]=0,bs[y[0]-'a'][x]=1;
str[x]=y[0];
}
else{
int z;scanf("%d%s",&z,y+1);
int len=strlen(y+1);
bitset<N> cur;cur.set();
for(int i=1;i<=len;i++) cur=(cur<<1)&bs[y[i]-'a'];
x+=len-1;
if(x>z){ puts("0");continue;}
cur>>=x;int ans=cur.count();
cur>>=(z-x+1);ans-=cur.count();
printf("%d\n",ans);
}
}
fprintf(stderr,"%d ms\n",int(1e3*clock()/CLOCKS_PER_SEC));
return 0;
}