【NOIP2013模拟】归途与征程
题目
分析
好吧。。。明显是暴力题。
首先,把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模拟】归途与征程的更多相关文章
- 【NOIP2013模拟】终极武器(经典分析+二分区间)
No.2. [NOIP2013模拟]终极武器 题意: 给定你一些区间,然后让你找出\(1\sim 9\)中的等价类数字. 也就是说在任何一个区间里的任何一个数,把其中后\(k\)位中的某一位换成等价类 ...
- JZOJ 3493. 【NOIP2013模拟联考13】三角形
3493. [NOIP2013模拟联考13]三角形(triangle) (File IO): input:triangle.in output:triangle.out Time Limits: 10 ...
- JZOJ 3487. 【NOIP2013模拟联考11】剑与魔法(dragons)
3487. [NOIP2013模拟联考11]剑与魔法(dragons) (Standard IO) Time Limits: 1000 ms Memory Limits: 131072 KB De ...
- JZOJ 3470. 【NOIP2013模拟联考8】最短路(path)
470. [NOIP2013模拟联考8]最短路(path) (Standard IO) Time Limits: 1000 ms Memory Limits: 262144 KB Detailed ...
- JZOJ 3388. 【NOIP2013模拟】绿豆蛙的归宿
3388. [NOIP2013模拟]绿豆蛙的归宿 (Standard IO) Time Limits: 1000 ms Memory Limits: 131072 KB Detailed Limi ...
- JZOJ 3463. 【NOIP2013模拟联考5】军训
3463. [NOIP2013模拟联考5]军训(training) (Standard IO) Time Limits: 2000 ms Memory Limits: 262144 KB Deta ...
- JZOJ 3462. 【NOIP2013模拟联考5】休息(rest)
3462. [NOIP2013模拟联考5]休息(rest) (Standard IO) Time Limits: 1000 ms Memory Limits: 262144 KB Detailed ...
- JZOJ 3461. 【NOIP2013模拟联考5】小麦亩产一千八(kela)
3461. [NOIP2013模拟联考5]小麦亩产一千八(kela) (Standard IO) Time Limits: 1000 ms Memory Limits: 262144 KB Det ...
- JZOJ 3509. 【NOIP2013模拟11.5B组】倒霉的小C
3509. [NOIP2013模拟11.5B组]倒霉的小C(beats) (File IO): input:beats.in output:beats.out Time Limits: 1000 ms ...
- JZOJ 3508. 【NOIP2013模拟11.5B组】好元素
3508. [NOIP2013模拟11.5B组]好元素(good) (File IO): input:good.in output:good.out Time Limits: 2000 ms Mem ...
随机推荐
- 阶段2 JavaWeb+黑马旅游网_15-Maven基础_第5节 使用骨架创建maven的java工程_18maven的java工程取mysql数据库
使用maven创建ava功能,然后读取数据库做一个测试. 我们做的持久层,没有和页面有交互,只做一个java工程就可以了 创建的是java工程,用不用骨架都可以.这里不使用骨架,直接next 直接fi ...
- Shiro 学习
<转载于 凯涛 博客> Shiro目录 第一章 Shiro简介 第二章 身份验证 第三章 授权 第四章 INI配置 第五章 编码/加密 第六章 Realm及相关对象 第七章 ...
- python3+selenium常用语法汇总
Selenium常用语法总结 一.Selenium常用定位语法 1.元素定位 (1)ID定位元素: find_element_by_id(‘’) (2)通过元素的类名称定位元素: find_eleme ...
- 社工 - By浏览器 - Google搜索技巧 - 汇总
google基本语法 Index of: 使用它可以直接进入网站首页下的所有文件和文件夹中 intext: 将返回所有在网页正文部分包含关键词的网页 intitle: 将返回所有网页标题中包含关键词的 ...
- (3.4)常用知识-char与varchar的选择
1.char与varchar的比较 (1)数据存储开销 [1]varchar列需要2个额外的字节来记录存储数据的长度 [2]每个可为null的char列,需要一些字节(空位图)来反应数据的为空性 [3 ...
- 关于Maven的安装和配置
1.Maven的介绍 1.Maven是一个项目管理工具(项目对象模型POM) 2.Maven可以管理项目中的jar包依赖 3.Maven的中央仓库地址 http://mvnrepository.com ...
- [多校联考2019(Round 5 T1)] [ATCoder3912]Xor Tree(状压dp)
[多校联考2019(Round 5)] [ATCoder3912]Xor Tree(状压dp) 题面 给出一棵n个点的树,每条边有边权v,每次操作选中两个点,将这两个点之间的路径上的边权全部异或某个值 ...
- Python入门之 Python内置函数
Python入门之 Python内置函数 函数就是以功能为导向,一个函数封装一个功能,那么Python将一些常用的功能(比如len)给我们封装成了一个一个的函数,供我们使用,他们不仅效率高(底层都是用 ...
- 使用ajax发送文件的三种方式及预览图片的方法,上传按钮美化
后端代码 def upload(request): if request.method == "GET": return render(request,'upload.html') ...
- k3 cloud中如何把一个账套中的单据部署到另一个账套中
打开bos,依次点击->解决方案->部署包管理 填写部署包名称并点击下一步 选择需要部署的单据并点击下一步 确定后点击下一步: 点击完成 找到部署路径会成一个部署包: 部署:打开部署包安装 ...