题目

分析

好吧。。。明显是暴力题。

首先,把A串分成只有小写字母组成的小分串,按顺序存放:A[1]、A[2]、A[3]……。

对于同构循环串,显然把两个B串合在一起,成为一个新的C串。\(C[i...i+m-1]\)(1<=i<=|B|)就是一个同构循环串。

接着设\(f[i][j]\)指在\(C[i+1...|C|]\)中第一个A[j]的位置,可以用kmp求出来。

然后就可以愉愉快快得暴力啦!

暴力:对于一个同构循环串\(C[i...i+|B|-1]\),设k=i-1,每次k调到下一个A的小分串的结尾(即k=f[k][j]+len[j]-1(当前做到的是第j个小分串)),当k>i+|B|-1,那么就是说在\(C[i...i+|B|-1]\)中没有对应的A串,break。

注意判断A串的开头结尾不是‘*’的情况。开头情况的:如果\(f[0][1]<>1\)就continue。结尾一样。

#include <cmath>
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <queue>
const int maxlongint=2147483647;
using namespace std;
char sm[210000],sn[110][110];
int n,m,ans,tot,pos[110],len[110],tt,f[200500][102];
int next[110];
int kmp(int x)
{
memset(next,0,sizeof(next));
int j=0;
for(int i=2;i<=len[x];i++)
{
while(j>0 && sn[x][i]!=sn[x][j+1])
j=next[j];
if(sn[x][i]==sn[x][j+1])
j++;
next[i]=j;
}
j=0;
for(int i=1;i<=2*m;i++)
{
while(j>0 && sm[i]!=sn[x][j+1])
j=next[j];
if(sm[i]==sn[x][j+1])
j++;
if(j==len[x])
{
f[i-j+1-1][x]=i-j+1;
}
}
}
int main()
{
scanf("%s\n%s\n",sn[0]+1,sm+1);
n=strlen(sn[0]+1);
m=strlen(sm+1);
for(int i=1;i<=m;i++)
{
sm[m+i]=sm[i];
}
for(int i=1;i<=n;i++)
{
if(sn[0][i]!='*')
{
pos[++tot]=i;
len[tot]=0;
while(sn[0][len[tot]+1+pos[tot]-1]!='*' && len[tot]+1+pos[tot]-1<=n)
{
sn[tot][++len[tot]]=sn[0][len[tot]+pos[tot]-1];
}
i=len[tot]+pos[tot]-1;
}
}
for(int j=1;j<=tot;j++)
kmp(j);
for(int i=2*m;i>=0;i--)
{
for(int j=1;j<=tot;j++)
{
if(!f[i+1][j])
f[i+1][j]=maxlongint/5;
if(!f[i][j])
{
f[i][j]=f[i+1][j];
}
}
}
for(int i=1;i<=m;i++)
{
if(sn[0][1]!='*')
{
if(f[i-1][1]!=i) continue;
}
if(sn[0][n]!='*')
{
if(f[i+m-1-len[tot]+1-1][tot]!=i+m-1-len[tot]+1) continue;
}
int k=i-1;
for(int j=1;j<=tot;j++)
{
k=f[k][j]+len[j]-1;
if(k>i+m-1)
{
ans--;
break;
}
}
ans++;
}
printf("%d",ans);
}

最新文章

  1. c# 如何中List&lt;object&gt;中去掉object对象中的重复列数据?
  2. 使用js批量选中功能实现更改数据库中的status状态值(批量展示)
  3. Xcode 8.2 想使用插件 怎么办? 教你科学的使用插件
  4. oracle的基本数据类型(转载)
  5. 新浪微博客户端(49)-删除输入的Emotion表情
  6. Android--TextView 文字显示和修改
  7. 在运行程序时报错:&quot;如果在 Code First 模式下使用,则使用 T4 模板为 Database First 和 Model First 开发生成的代码可能无法 正常运行。若要继续使用 Database First 或 Model First,请确保在执行应用程序的 config 文件中指 定 Entity Framework 连接字符串。若要将这些从 Database First 或 Mod
  8. Java 常用排序算法/程序员必须掌握的 8大排序算法
  9. HTML5 CSS3简要教程
  10. maven3实战之maven使用入门(使用archetype生成项目骨架)
  11. UVa12657 - Boxes in a Line(数组模拟链表)
  12. SQL Join 的三种类型
  13. ubuntu 14.04 安装preforce
  14. Microsoft Azure 上的自定义数据和 Cloud-Init
  15. 教你MySQL Binlog实用攻略
  16. idea没配置Tomcat容器报错及解决方法
  17. VB中将类标记为可序列化
  18. C#核心基础--静态类&amp;部分类
  19. python5-10 检查用户名
  20. iOS开发tableView去掉顶部上部空表区域

热门文章

  1. django的url的name参数的意义及view中reverse
  2. windows,oracle,dg报错:ORA-12528,ORA-12154,ORA-10456 ,PING[ARC1]: Heartbeat failed to connect to standby &#39;orclbk&#39;. Error is 12154
  3. Java面试题全集(中)
  4. Python子类调用父类内属性的方法
  5. Servlet生命周期 Servlet获取配置信息 ServletContext
  6. 动态网页基础——JSP
  7. 【Linux开发】Linux磁盘管理
  8. kafak学习(一)
  9. mysql日志信息查看与设置mysql-bin
  10. 正斜杠&quot;/&quot;与反斜杠&quot;\&quot;