nyoj -5 Binary String Matching 【kmp】
2015-10-10 19:56
537 查看
Binary String Matching
时间限制:3000 ms | 内存限制:65535 KB难度:3
描述 Given two strings A and B, whose alphabet consist only ‘0’ and ‘1’. Your task is only to tell how many times does A appear as a substring of B? For example, the text string B is ‘1001110110’ while the pattern string A is ‘11’, you should output 3, because
the pattern A appeared at the posit
输入The first line consist only one integer N, indicates N cases follows. In each case, there are two lines, the first line gives the string A, length (A) <= 10, and the second line gives the string B, length (B) <= 1000. And it is guaranteed that B is always
longer than A.输出For each case, output a single line consist a single integer, tells how many times do B appears as a substring of A.样例输入
3 11 1001110110 101 110010010010001 1010 110100010101011
样例输出
3 0 3
分析:
这道题没有太多的解释,裸的kmp,不过其中一点要注意。
代码:
[code]#include<cstdio> #include<cstring> #include<cstdlib> #include<algorithm> #define maxn 1010 using namespace std; char s1[maxn],s2[maxn]; int next[maxn]; int len1,len2; int ans; void getp() { int i=0,j=-1; next[0]=-1; while(i<len1) { if(j==-1||s1[i]==s1[j])//如果换成s1[i]==s2[j],则查找的数据不能出现重复查找过的,就像最后一组数据。 { i++; j++; next[i]=j; } else j=next[j]; } } void kmp() { getp(); int i=0,j=0; while(i<len2) { if(j==-1||s1[j]==s2[i]) { i++; j++; if(j==len1) ans++; } else j=next[j]; } } int main() { int n; scanf("%d",&n); while(n--) { ans=0; scanf("%s%s",s1,s2); len1=strlen(s1); len2=strlen(s2); kmp(); printf("%d\n",ans); } return 0; }
[/code]
相关文章推荐
- JuQueen(线段树 lazy)
- C++的64位整数
- JuQueen(线段树 lazy)
- Xocde7 https 问题
- 为什么我的效率低
- 面向对象
- ViewPager之图片的切换
- tools:context=".MainActivity的作用
- Python自然语言处理NLTK(1.1-1.3)
- LINUX查看系统日志
- Java语言基础(数组概述和定义格式说明)
- hdu 1565 方格取数(1)【最大流】
- 【C#】ToString()参数中格式解析大全
- 【HNOI2006】【BZOJ1191】超级英雄Hero
- IOS-9-UIBarButtonItem导航条-添加自定义Left或者Right按钮
- C++学习笔记6——string
- Atitit.Hibernate于Criteria 使用汇总and 关系查询 and 按照子对象查询 o9o
- sqrt()平方根计算函数的实现1——二分法
- 使用Linq 来解决Datatable 去除数据重复
- Java语言基础(常量的概述和使用)