Posted on 2008-08-26 16:48
dengbo 阅读(356)
评论(0) 编辑 收藏 引用 所属分类:
Data Struct
#include "stdafx.h"
#include <iostream>
using namespace std;
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
int KMP_Search(const char *,const char*,const int *);
void getNext(const char*,int*);
int _tmain(int argc, _TCHAR* argv[])
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt=""
{
char S[50]="ABC ABCDAB ABCDABCDABDE";
char W[10]="ABCDABD";
int next[10];
getNext(W,next);
data:image/s3,"s3://crabby-images/f74aa/f74aa0daa97912d7a2dcb8fc685747aa4f541b5c" alt=""
int m = KMP_Search(W,S,next);
cout<<m<<endl;
system("pause");
return 0;
}
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
int KMP_Search(const char *W,const char*S,const int * next)
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt=""
{
int m=0,i=0,wlen = strlen(W);
while(m+i<strlen(S))
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
if(W[i] == S[m+i])
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{ i++;
if(i==wlen)
return m;
}
else
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
m=m + i - next[i];
if (i>0)
i=next[i];
}
}
}
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
void getNext(const char* S,int next[])
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt=""
{
int pos=2,cnd=0;
next[0]= -1;
next[1] = 0;
while(pos<strlen(S))
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
if(S[pos-1] == S[cnd])
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
next[pos] = cnd+1;
pos++;
cnd++;
}
if(S[pos-1] != S[cnd] && cnd>0)
cnd = next[cnd];
if (cnd == 0)
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
next[pos] = 0;
pos++;
}
}
}
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""