#include
typedef struct
{
char *ch;
int len;
}st;//字符串结构定义
void getnext(st substr,int next[])//覆盖函数
{
int i=0,j=-1;
next[0]=-1;
while (i<substr.len)
{
if(j==-1||substr.ch[i]==substr.ch[j])
{
next[++i]=++j;
}
else
j=next[j];
}
}
//以下是主要算法-kmp
int kmp(st str,st substr,int next[])
{
int i=0,j=0;
while (i<str.len && j<substr.len)
{
if(str.ch[i]==substr.ch[j])
{
++i;
++j;
}
else
{
j=next[j];
if(j==-1)
{
j=0;
++i;
}
}
}
if (j==substr.len)
return i-substr.len;
else return -1;
}
//主函数
int main()
{
int next[100];
int position;
st str;
st substr;
puts("请输入一段文章:");
gets(str.ch);
puts("请输入您想找到的一段文字:");
gets(substr.ch);
getnext(substr,next);
position = kmp(str,substr,next);
if(position!=-1)
printf("%d",position);
else
puts("error");
}