#1015 : KMP算法
时间限制:1000ms
单点时限:1000ms
内存限制:256MB
- 例子输入
-
5 HA HAHAHA WQN WQN ADA ADADADA BABABB BABABABABABABABABB DAD ADDAADAADDAAADAAD
- 例子输出
-
3 1 3 1
0
-
没什么好说的,模板题
-
#include<cstdio> #include<cstring> #include<algorithm> #include <iostream> #include <string> using namespace std; int f[ 15000]; void getfill(string s) { memset(f,0,sizeof(f)); //依据其前一个字母得到 for(int i=1;i<s.size();i++) { int j=f[i]; while(j && s[i]!=s[j]) j=f[j]; f[i+1]=(s[i]==s[j])?j+1:0; } } int find(string a,string s) { int ans=0; getfill(s);int j=0; for(int i=0;i<a.size();i++) { while(j && a[i]!=s[j]) j=f[j]; if(a[i]==s[j]) j++; if(j==s.size()){ ans++; } } return ans; } int main() { string s,a; int T; scanf("%d",&T); while(T--) { getchar(); cin>>s>>a; int ans=find(a,s); printf("%d ",ans); } return 0; }
描写叙述
小Hi和小Ho是一对好朋友,出生在信息化社会的他们对编程产生了莫大的兴趣。他们约定好互相帮助,在编程的学习道路上一同前进。
这一天。他们遇到了一仅仅河蟹,于是河蟹就向小Hi和小Ho提出了那个经典的问题:“小Hi和小Ho,你们能不可以推断一段文字(原串)里面是不是存在那么一些……特殊……的文字(模式串)?”
小Hi和小Ho细致思考了一下,认为仅仅能想到非常easy的做法,可是又认为既然河蟹先生这么说了,就肯定不会这么easy的让他们回答了。于是他们仅仅能说道:“抱歉,河蟹先生,我们仅仅能想到时间复杂度为(文本长度 * 特殊文字总长度)的方法,即对于每一个模式串分开推断,然后依次枚举起始位置并检查是否可以匹配,可是这不是您想要的方法是吧?”
河蟹点了点头,说道:”看来你们的水平还有待提高。这样吧。假设我说仅仅有一个特殊文字,你能不能做到呢?“
小Ho这时候还有点晕晕乎乎的,可是小Hi非常快开口道:”我知道!这就是一个非常经典的模式匹配问题!
能够使用KMP算法进行求解。“
河蟹惬意的点了点头,对小Hi说道:”既然你知道就好办了,你去把小Ho教会。下周我有重要的任务交给你们。“
”保证完毕任务。”小Hi点头道。
输入
第一行一个整数N。表示測试数据组数。
接下来的N*2行,每两行表示一个測试数据。
在每个測试数据中。第一行为模式串,由不超过10^4个大写字母组成。第二行为原串,由不超过10^6个大写字母组成。
当中N<=20
输出
对于每个測试数据。依照它们在输入中出现的顺序输出一行Ans。表示模式串在原串中出现的次数。