【Codeforces】 CF914F Substrings in a String

题目链接

CF方向
Luogu方向

题目解法

又学会了一种字符串匹配 + 骗分技巧!!!

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 <bits/stdc++.h>
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;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值