您的位置:首页 > 其它

hihocoder 1015 KMP

2015-04-09 21:53 302 查看
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <string.h>
using namespace std;
int ans;
char ch[1000005];
char m[10005];
int na[10005];

void next(){
	na[0] = -1;
	int j = -1;
	int i = 0;
	while(m[i]){
		if(j == -1 || m[i] == m[j]){
			j++;
			i++;
			na[i] = j;
		}
		else{
			j = na[j];
		}
	}
}
int main(){
	int n;
	scanf("%d",&n);
	while(n--)
	{
		scanf("%s%s",m,ch);
		
		int len = strlen(m);		
		next();
		
		ans  = 0;
		int j = 0;
		for(int i = 0; ch[i];){
			if(j == -1|| ch[i] == m[j]){
				i++;
				j++;
				if(j == len){
					ans ++;
					j = na[j];	 
				}
			}
			else{
				j = na[j];
			}
		}
		printf("%d\n",ans);
	}
	return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: