标签:
题目大意:
找到所有的可组成连续字符串相连的位置,和循环字符串的个数
#include <cstdio> #include <cstring> #include <algorithm> #include <vector> #include <queue> #include <climits> #include <cmath> #include <cstdlib> using namespace std; #define ll long long #define N 1000100 char s[N] , b[N]; int _next[N] , len1 , len2; void get_next(int n) { _next[0] = _next[1] = 0; for(int i=1 ; i<n ; i++){ int j = _next[i]; while(j&&b[i]!=b[j]) j=_next[j]; if(b[i]==b[j]) _next[i+1] = j+1; else _next[i+1] = 0; } } int kmp(int n) { int ret = 0; int i , j=0; for(i=0 ; i<n ; i++){ if(s[i]==b[j]) j++; else{ while(j&&s[i]!=b[j]) j=_next[j]; if(!j && s[i]!=b[j]) j=0; else j++; } if(j==len2) ret++ , j=0; } return ret; } int main() { #ifndef ONLINE_JUDGE freopen("a.in" , "r" , stdin); #endif while(scanf("%s" , s) , s[0]!=‘#‘) { scanf("%s" , b); len1 = strlen(s) , len2 = strlen(b); get_next(len2); printf("%d\n" , kmp(len1)); } return 0; }
标签:
原文地址:http://www.cnblogs.com/CSU3901130321/p/4599011.html