1.掌握Next数组的意义:当前前缀和后缀最大匹配数。如abcab,为2.
2.掌握循环节:int len=tlen-Next[tlen];
const int N = 1000005;
int Next[N];
int S[N], T[N];//母串 子串
int slen,tlen;
void getNext() //求next数组
{
int j, k;
j = 0; k = -1; Next[0] = -1;
while(j < tlen)
if(k == -1 || T[j] == T[k])
Next[++j] = ++k;
else
k = Next[k];
}
int KMP_Count() //子串数目
{
int ans = 0;
int i, j = 0;
if(slen == 1 && tlen == 1)
{
if(S[0] == T[0])
return 1;
else
return 0;
}
getNext();
for(i = 0; i < slen; i++)
{
while(j>=0 && S[i] != T[j])
j = Next[j];
if(j==-1||S[i] == T[j])
j++;
if(j == tlen)
{
ans++;
j = Next[j];
//当不能重复使用单个字符时 j=0;
}
}
return ans;
}
int KMP_Index() //子串第一次出现的位置
{
int i = 0, j = 0;
getNext();
while(i < slen && j < tlen)
{
if(j == -1 || S[i] == T[j])
{
i++; j++;
}
else
j = Next[j];
}
if(j == tlen)
return i - tlen+1;
else
return -1;
}