记录编号 251110 评测结果 AAAAAAAAAA
题目名称 [BZOJ 4503] 你猜是不是KMP 最终得分 100
用户昵称 GravatarTenderRun 是否通过 通过
代码语言 C++ 运行时间 4.008 s
提交时间 2016-04-16 21:26:01 内存使用 36.17 MiB
显示代码纯文本
  1. #include <iostream>
  2. #include <cstring>
  3. #include <cstdio>
  4. #include <cmath>
  5. using namespace std;
  6. const int maxn=400010;
  7. const double PI=acos(-1.0);
  8. char s[maxn],t[maxn];
  9. int a[maxn],b[maxn];
  10. struct complex{
  11. double r,i;
  12. complex(double r_=0.0,double i_=0.0){
  13. r=r_;i=i_;
  14. }
  15. complex operator +(complex a){
  16. return complex(r+a.r,i+a.i);
  17. }
  18. complex operator -(complex a){
  19. return complex(r-a.r,i-a.i);
  20. }
  21. complex operator *(complex a){
  22. return complex(r*a.r-i*a.i,r*a.i+i*a.r);
  23. }
  24. };
  25. complex A[maxn],B[maxn],C[maxn],D[maxn],E[maxn];
  26.  
  27. void Rader(complex *a,int len){
  28. int k;
  29. for(int i=1,j=len>>1;i<len-1;i++){
  30. if(i<j)swap(a[i],a[j]);
  31. k=len>>1;
  32. while(j>=k){
  33. j-=k;
  34. k>>=1;
  35. }
  36. j+=k;
  37. }
  38. }
  39.  
  40. void FFT(complex *a,int len,int on){
  41. Rader(a,len);
  42. for(int h=2;h<=len;h<<=1){
  43. complex wn(cos(on*PI*2.0/h),sin(on*PI*2.0/h));
  44. for(int j=0;j<len;j+=h){
  45. complex w(1,0);
  46. for(int k=j;k<j+(h>>1);k++){
  47. complex u=a[k];
  48. complex v=a[k+(h>>1)]*w;
  49. a[k]=u+v;
  50. a[k+(h>>1)]=u-v;
  51. w=w*wn;
  52. }
  53. }
  54. }
  55. if(on==-1)
  56. for(int i=0;i<len;i++)
  57. a[i].r/=len;
  58. }
  59. int ans[maxn],tot;
  60. int main(){
  61. freopen("guess.in","r",stdin);
  62. freopen("guess.out","w",stdout);
  63. scanf("%s%s",s,t);
  64. int lens=strlen(s);
  65. int lent=strlen(t);
  66. for(int i=0;i<lens;i++)
  67. a[i]=s[i]-'a'+1;
  68. for(int i=0;i<lent;i++){
  69. if(t[i]=='?')
  70. b[lent-i-1]=0;
  71. else
  72. b[lent-i-1]=t[i]-'a'+1;
  73. }
  74. int len=1;
  75. while(len<lens+lent)len<<=1;
  76. for(int i=0;i<lens;i++)A[i]=complex(1.0,0);
  77. for(int i=0;i<lent;i++)B[i]=complex(1.0*b[i]*b[i]*b[i],0);
  78. FFT(A,len,1);FFT(B,len,1);
  79. for(int i=0;i<len;i++)C[i]=A[i]*B[i];
  80. FFT(C,len,-1);
  81. memset(A,0,sizeof(A));
  82. memset(B,0,sizeof(B));
  83. for(int i=0;i<lens;i++)A[i]=complex(2.0*a[i],0);
  84. for(int i=0;i<lent;i++)B[i]=complex(1.0*b[i]*b[i],0);
  85. FFT(A,len,1);FFT(B,len,1);
  86. for(int i=0;i<len;i++)D[i]=A[i]*B[i];
  87. FFT(D,len,-1);
  88. memset(A,0,sizeof(A));
  89. memset(B,0,sizeof(B));
  90. for(int i=0;i<lens;i++)A[i]=complex(1.0*a[i]*a[i],0);
  91. for(int i=0;i<lent;i++)B[i]=complex(1.0*b[i],0);
  92. FFT(A,len,1);FFT(B,len,1);
  93. for(int i=0;i<len;i++)E[i]=A[i]*B[i];
  94. FFT(E,len,-1);
  95. for(int i=lent-1;i<lens;i++)
  96. if(fabs(C[i].r-D[i].r+E[i].r)<1e-5)
  97. ans[++tot]=i-lent+1;
  98. printf("%d\n",tot);
  99. for(int i=1;i<=tot;i++)
  100. printf("%d\n",ans[i]);
  101. return 0;
  102. }