BZOJ4259 残缺的字符串 多项式 FFT
原文链接http://www.cnblogs.com/zhouzhendong/p/8798532.html
题目传送门 - BZOJ4259
题意
给你两个串,用其中一个来匹配另一个。问从母串的那些位置开始可以匹配模式串。注意有"*"可以匹配任何字符。
串长$\leq 3\times 10^5$。
题解
本题和BZOJ4503几乎一毛一样。
  这里直接放BZOJ4503的传送门。
  http://www.cnblogs.com/zhouzhendong/p/8536065.html
但是这题要略微卡一卡时间和空间。
这题让我第一次感受到了寻址的效率之慢。
通过测试,同样是访问大约$8400000$个地址,仅通过改变访问顺序,我可以测出最快访问速度大约13倍的最慢访问速度。就是通过改变访问$8400000$个位置的顺序,使得$460MS\rightarrow 5500MS$(谢谢BZOJ测评器,如果我选紫荆花之恋来测试的话可能得到的数据会更好哈哈,但我不敢)。(但这个应该不是上限)
真的是QAQ。
我写的$FFT$中对$w_{t\times j}$的寻址特别慢,所以导致效率慢了约$3000MS$。写成$Claris$的写法,可以把我的程序卡到$5000MS$(虽然精度会稍微差一点但是可以承受)。
代码
#include <bits/stdc++.h>
#define y1 ______y1
using namespace std;
typedef long long LL;
const int N=1<<20;
const double PI=acos(-1.0);
int n,L,R[N];
struct C{
double r,i;
C(){}
C(double a,double b){r=a,i=b;}
C operator + (C x){return C(r+x.r,i+x.i);}
C operator - (C x){return C(r-x.r,i-x.i);}
C operator * (C x){return C(r*x.r-i*x.i,r*x.i+i*x.r);}
void operator = (double x){r=x,i=0;}
}w[N],x1[N],x2[N],y1[N],y2[N],z[N];
int L1,L2,a[N],b[N];
LL res[N];
char s1[N],s2[N];
void FFT(C a[]){
for (int i=0;i<n;i++)
if (i<R[i])
swap(a[i],a[R[i]]);
for (int t=n>>1,d=1;d<n;d<<=1,t>>=1)
for (int i=0;i<n;i+=(d<<1))
for (int j=0,prod=0;j<d;j++,prod+=t){
C tmp=w[prod]*a[i+j+d];
a[i+j+d]=a[i+j]-tmp;
a[i+j]=a[i+j]+tmp;
}
}
int ans[N],acnt=0;
int main(){
scanf("%d%d%s%s",&L2,&L1,s2,s1);
for (int i=0;i<L2/2;i++)
swap(s2[i],s2[L2-i-1]);
for (int i=0;i<L1;i++)
a[i]=s1[i]=='*'?0:(s1[i]-'a'+1);
for (int i=0;i<L2;i++)
b[i]=s2[i]=='*'?0:(s2[i]-'a'+1);
for (n=1,L=0;n<L1+L2;n<<=1,L++);
for (int i=0;i<n;i++){
R[i]=(R[i>>1]>>1)|((i&1)<<(L-1));
w[i]=C(cos(2*i*PI/n),sin(2*i*PI/n));
}
memset(res,0,sizeof res);
for (int i=0;i<n;i++){
x1[i]=1.0*a[i]*a[i]*a[i],y1[i]=1.0*b[i];
x2[i]=1.0*a[i]*a[i],y2[i]=1.0*b[i]*b[i];
}
FFT(x1),FFT(x2),FFT(y1),FFT(y2);
for (int i=0;i<n;i++){
z[i]=x1[i]*y1[i]-C(2.0,0)*x2[i]*y2[i];
x1[i]=1.0*a[i],y1[i]=1.0*b[i]*b[i]*b[i];
}
FFT(x1),FFT(y1);
for (int i=0;i<n;i++){
z[i]=z[i]+x1[i]*y1[i];
w[i].i*=-1.0;
}
FFT(z);
for (int i=0;i<n;i++)
res[i]=(LL)(z[i].r/n+0.5);
for (int i=L2-1;i<L1;i++)
if (res[i]==0)
ans[++acnt]=i-L2+2;
printf("%d\n",acnt);
for (int i=1;i<=acnt;i++)
printf("%d ",ans[i]);
return 0;
}
BZOJ4259 残缺的字符串 多项式 FFT的更多相关文章
- BZOJ4259 残缺的字符串 【fft】
		题目 很久很久以前,在你刚刚学习字符串匹配的时候,有两个仅包含小写字母的字符串A和B,其中A串长度为m,B串长度为n.可当你现在再次碰到这两个串时,这两个串已经老化了,每个串都有不同程度的残缺. 你想 ... 
- BZOJ4259 残缺的字符串(FFT)
		两个串匹配时相匹配的位置位置差是相同的,那么翻转一个串就变成位置和相同,卷积的形式. 考虑如何使用卷积体现两个位置能否匹配.一个暴力的思路是每次只考虑一种字符,将其在一个串中设为1,并在另一个串中将不 ... 
- 2018.11.17 bzoj4259: 残缺的字符串(fft)
		传送门 fftfftfft套路题. 我们把aaa ~ zzz映射成111 ~ 262626,然后把∗*∗映射成000. 考虑对于两个长度都为nnn的字符串A,BA,BA,B. 我们定义一个差异函数di ... 
- 【BZOJ4259】残缺的字符串(FFT)
		[BZOJ4259]残缺的字符串(FFT) 题面 给定两个字符串\(|S|,|T|\),两个字符串中都带有通配符. 回答\(T\)在\(S\)中出现的次数. \(|T|,|S|<=300000\ ... 
- CF528D Fuzzy Search 和 BZOJ4259 残缺的字符串
		Fuzzy Search 给你文本串 S 和模式串 T,求 S 的每个位置是否能模糊匹配上 T. 这里的模糊匹配指的是把 T 放到 S 相应位置上之后,T 中每个字符所在位置附近 k 个之内的位置上的 ... 
- BZOJ4259:残缺的字符串(FFT)
		Description 很久很久以前,在你刚刚学习字符串匹配的时候,有两个仅包含小写字母的字符串A和B,其中A串长度为m,B串长度为n.可当你现在再次碰到这两个串时,这两个串已经老化了,每个串都有不同 ... 
- BZOJ4259:残缺的字符串(FFT与字符串匹配)
		很久很久以前,在你刚刚学习字符串匹配的时候,有两个仅包含小写字母的字符串A和B,其中A串长度为m,B串长度为n.可当你现在再次碰到这两个串时,这两个串已经老化了,每个串都有不同程度的残缺. 你想对这两 ... 
- BZOJ4259: 残缺的字符串(FFT 字符串匹配)
		题意 题目链接 Sol 知道FFT能做字符串匹配的话这就是个裸题了吧.. 考虑把B翻转过来,如果\(\sum_{k = 0}^M (B_{i - k} - A_k)^2 * B_{i-k}*A_k = ... 
- BZOJ4259残缺的字符串
		题目描述 很久很久以前,在你刚刚学习字符串匹配的时候,有两个仅包含小写字母的字符串A和B,其中A串长度为m,B串长度为n.可当你现在再次碰到这两个串时,这两个串已经老化了,每个串都有不同程度的残缺. ... 
随机推荐
- LCD学习
			LCD简介(1)显示器,常见显示器(2)LCD(Liquid Crystal Display),液晶显示器,原理介绍(3)LCD应用领域(4)LED OLED1.17.1.2.电子显示器的原理(1)像 ... 
- kotlin电商学习记录,好久没来逛逛了
			好久没来,一直做毕业设计,用kotlin写一个基于以图搜图的购物app,现在又赶上实习,内容多,时间少,不过前途光明并由贵人指点.加油 kotlin电商学习记录 技术选型 视图层 kotlin-and ... 
- Django 视图系统
			Django 视图系统 概念 一个视图函数,简称视图,是一个简单的Python函数,用于接受Web请求并返回Web响应. 通常将视图函数写在project或app目录中的名为views.py文件中 简 ... 
- 【并发编程】MESI--CPU缓存一致性协议
			原文:多线程之:MESI-CPU缓存一致性协议 概念 MESI(Modified Exclusive Shared Or Invalid)(也称为伊利诺斯协议,是因为该协议由伊利诺斯州立大学提出)是一 ... 
- 关于opencv的cv2.WINDOW_一类
			用法:cv2.namedWindow('窗口标题',默认参数) 默认参数:cv2.WINDOW_AUTOSIZE+cv2.WINDOW_KEEPRATIO+cv2.WINDOW_GUI_EXPANDE ... 
- 20175209 《Java程序设计》第五周学习总结
			20175209 <Java程序设计>第五周学习总结 一.教材知识点总结 1.接口的定义 接口声明:关键字interface 接口体:public static final 修饰常量,pu ... 
- openstack项目【day23】:keystone组件HTTP协议
			阅读目录 一 为何要学习HTTP协议 二 用户上网过程 三 HTTP协议 part1 http协议概述 part2 请求协议 part3 响应协议 四 抓包分析HTTP协议 一 为何要学习HTTP协议 ... 
- openstack项目【day23】:KVM介绍
			阅读目录 什么是kvm 为何要用kvm kvm的功能 常见虚拟化模式 KVM架构 KVM工具集合 一 什么是kvm KVM 全称 Kernel-Based Virtual Machine.也就是说 K ... 
- Object is not a function
			如图报了一个这样的错,百度好多都说是函数名和html元素重名的问题.可是这个问题我想我这里是不存在的 可以看到就一个绑定事件,而且id名不是关键字 报错是在$.ajax这一行,索性就把submit-i ... 
- Leetcode#13. Roman to Integer(罗马数字转整数)
			题目描述 罗马数字包含以下七种字符:I, V, X, L,C,D 和 M. 字符 数值 I 1 V 5 X 10 L 50 C 100 D 500 M 1000 例如, 罗马数字 2 写做 II ,即 ... 
