标签:
Description
Input
Output
Sample Input
Sample Output
解题思路:
直接上kmp,先对模式串通过O(m)的时间复杂度,计算出next[],然后通过kmp找到找到第一次匹配成功的模式串在文本串中的位置,然后输出
t1-len2+1就OK了。
代码:
1 # include<cstdio> 2 # include<iostream> 3 # include<cstring> 4 5 using namespace std; 6 7 8 int a[1000004]; 9 int b[10004]; 10 int nxt[10004]; 11 int n,m; 12 13 void get_next() 14 { 15 int len = m; 16 int t1 = 0, t2; 17 t2 = nxt[0] = -1; 18 while ( t1<len ) 19 { 20 if ( t2==-1||b[t1]==b[t2] ) 21 { 22 t1++;t2++; 23 nxt[t1] = t2; 24 } 25 else 26 t2 = nxt[t2]; 27 } 28 } 29 30 31 int kmp ( int *a,int *b ) 32 { 33 int len1 = n, len2 = m; 34 int t1 = 0,t2 = 0; 35 while ( t1<len1&&t2<len2 ) 36 { 37 if ( t2==-1||a[t1]==b[t2] ) 38 { 39 t1++;t2++; 40 } 41 else 42 t2 = nxt[t2]; 43 } 44 if ( t2==len2 ) 45 return t1-t2+1; 46 else 47 return -1; 48 } 49 50 51 int main(void) 52 { 53 int t;scanf("%d",&t); 54 while ( t-- ) 55 { 56 scanf("%d%d",&n,&m); 57 for ( int i = 0;i < n;i++ ) 58 scanf("%d",&a[i]); 59 for ( int j = 0;j < m;j++ ) 60 scanf("%d",&b[j]); 61 get_next(); 62 int ans = kmp(a,b); 63 printf("%d\n",ans); 64 } 65 66 67 68 return 0; 69 }
Problem A Number Sequence(KMP基础)
标签:
原文地址:http://www.cnblogs.com/wikioibai/p/4537475.html