AABCD CDAA ASD ASDF
yes no
就是把第一个串加倍后能不能包含第一个串
kmp模板
#include<iostream> #include<cstdio> #include<cstring> #include<string> #include<algorithm> #include<cmath> #include<queue> #include<vector> #define L(x) (x<<1) #define R(x) (x<<1|1) #define MID(x,y) ((x+y)>>1) using namespace std; #define N 200005 char a[N],b[N]; int next[N]; void getfail(char *b) { int i,j; i=0,j=-1; next[0]=-1; int len=strlen(b); while(i<len) { if(j==-1||b[i]==b[j]) { i++; j++; next[i]=j; } else j=next[j]; } } int kmp(char *a,char *b) { int i,j; int lena=strlen(a); int lenb=strlen(b); i=j=0; while(i<lena) { if(j==-1||a[i]==b[j]) { i++; j++; } else j=next[j]; if(j==lenb) return 1; } return 0; } int main() { int i,j; while(~scanf("%s%s",a,b)) { int len=strlen(a); for(i=0;i<len;i++) a[len+i]=a[i]; a[i+len]='\0'; getfail(b); if(kmp(a,b)) printf("yes\n"); else printf("no\n"); } return 0; }
原文地址:http://blog.csdn.net/u014737310/article/details/40350765