题目

分析

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

首先,把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);
}

【NOIP2013模拟】归途与征程的更多相关文章

  1. 【NOIP2013模拟】终极武器(经典分析+二分区间)

    No.2. [NOIP2013模拟]终极武器 题意: 给定你一些区间,然后让你找出\(1\sim 9\)中的等价类数字. 也就是说在任何一个区间里的任何一个数,把其中后\(k\)位中的某一位换成等价类 ...

  2. JZOJ 3493. 【NOIP2013模拟联考13】三角形

    3493. [NOIP2013模拟联考13]三角形(triangle) (File IO): input:triangle.in output:triangle.out Time Limits: 10 ...

  3. JZOJ 3487. 【NOIP2013模拟联考11】剑与魔法(dragons)

    3487. [NOIP2013模拟联考11]剑与魔法(dragons) (Standard IO) Time Limits: 1000 ms  Memory Limits: 131072 KB  De ...

  4. JZOJ 3470. 【NOIP2013模拟联考8】最短路(path)

    470. [NOIP2013模拟联考8]最短路(path) (Standard IO) Time Limits: 1000 ms  Memory Limits: 262144 KB  Detailed ...

  5. JZOJ 3388. 【NOIP2013模拟】绿豆蛙的归宿

    3388. [NOIP2013模拟]绿豆蛙的归宿 (Standard IO) Time Limits: 1000 ms  Memory Limits: 131072 KB  Detailed Limi ...

  6. JZOJ 3463. 【NOIP2013模拟联考5】军训

    3463. [NOIP2013模拟联考5]军训(training) (Standard IO) Time Limits: 2000 ms  Memory Limits: 262144 KB  Deta ...

  7. JZOJ 3462. 【NOIP2013模拟联考5】休息(rest)

    3462. [NOIP2013模拟联考5]休息(rest) (Standard IO) Time Limits: 1000 ms  Memory Limits: 262144 KB  Detailed ...

  8. JZOJ 3461. 【NOIP2013模拟联考5】小麦亩产一千八(kela)

    3461. [NOIP2013模拟联考5]小麦亩产一千八(kela) (Standard IO) Time Limits: 1000 ms  Memory Limits: 262144 KB  Det ...

  9. JZOJ 3509. 【NOIP2013模拟11.5B组】倒霉的小C

    3509. [NOIP2013模拟11.5B组]倒霉的小C(beats) (File IO): input:beats.in output:beats.out Time Limits: 1000 ms ...

  10. JZOJ 3508. 【NOIP2013模拟11.5B组】好元素

    3508. [NOIP2013模拟11.5B组]好元素(good) (File IO): input:good.in output:good.out Time Limits: 2000 ms  Mem ...

随机推荐

  1. Linux_KVM虚拟机

    目录 目录 Hpyervisor的种类 安装KVM 使用virsh指令管理虚拟机 KVM虚拟机的网络设置 Hpyervisor的种类 hpyervisor:是一种VMM(Virtual Machine ...

  2. Jmeter之Synchronizing Timer(同步集合点)

    在性能测试时,需要压测并发,此时就需要用到Synchronizing Timer组件. 一.界面显示 二.配置说明 1.名称:标识 2.注释:备注 3.Grouping (1.Number of si ...

  3. Unity ZTest 深度测试 & ZWrite 深度写入

    初学Shader,一开始对于渲染队列,ZTest 和 ZWrite一头雾水,经过多方查阅和实验,有了一些自己的理解.发此文与初学Shader的朋友分享,也算是为自己做个笔记.不对或不足之处欢迎指正. ...

  4. 使用Postman对HTTP接口进行功能测试

    一.工具说明 Postman是一种网页调试与发送网页http请求的工具.我们可以用来很方便的模拟get或者post或者其他方式的请求来调试接口. 二.应用场景 1.Get请求 get请求通过接口参数拼 ...

  5. Java基础之 多线程

    一.创建多线程程序的第一种方式: 继承(extends) Thread类 Thread类的子类: MyThread //1.创建一个Thread类的子类 public class MyThread e ...

  6. MySQL学习-数据库设计以及sql的进阶语句

    1.数据库设计 关系型数据库建议在E-R模型的基础上,我们需要根据产品经理的设计策划,抽取出来模型与关系,制定出表结构,这是项目开始的第一步 在开发中有很多设计数据库的软件,常用的如power des ...

  7. 关于java范型

    1 范型只在编译阶段有效 编译器在编译阶段检查范型结果之后,就会将范型信息删除.范型信息不会进入运行时阶段. 泛型类型在逻辑上看以看成是多个不同的类型,实际上都是相同的基本类型. 2 不能对确定的范型 ...

  8. JAVA poi设置单元格背景颜色

    import java.io.FileOutputStream; import java.io.IOException;   import org.apache.poi.ss.usermodel.Ce ...

  9. MyBatis框架 课程笔记

    MyBatis框架 课程笔记   第1章 MyBatis简介 1.1 MyBatis历史 1)MyBatis是Apache的一个开源项目iBatis, 2010年6月这个项目由Apache Softw ...

  10. 断开ssh链接在后台继续运行命令

    转载:http://blog.csdn.net/v1v1wang/article/details/6855552 对于linux运维,我们都是使用ssh登录到服务器,如果我们运行的任务需要很长时间或不 ...