KMP算法过程及C++代码

KMP算法思想

KMP算法是D.E.Knuth,J.H.Morris和V.R.Pratt共同提出的,简称为KMP算法。
该算法较BF算法有较大的改进每当一趟匹配过程中出现字符不相等时,主串指示器 i 不用回溯,而是利用已经得到的“部分匹配”结果,将模式串向右“滑动”尽可能远的一段距离后,与 i 对齐,继续进行比较。

KMP算法过程示例

在这里插入图片描述
当 i = 3,j = 3时失配。
此时按照BF算法,将子串P右移一位:

在这里插入图片描述

按照KMP算法,尽可能的多移几位,i 的位置不变,使得模式P中的某个位置继续与 i 进行比较
在这里插入图片描述
发现当 i = 7,j = 5时失配:
在这里插入图片描述
模式P继续向右滑动,进行第三次匹配:
在这里插入图片描述
此时匹配完成。

确定next[ ] 函数

在这里插入图片描述

因此我们需要对模板s[ ]进行预处理:
以 i 为终点的后缀 = 从1开始的前缀,且长度最长
在这里插入图片描述
即next[ i ] = j :
s[ 1…j ]这一段 = s[ i-j+1 … i ] 这一段

C++代码实现

注:s[ ]下标从1开始,p[ ]下标从0开始,所以s[ i ] 对应的是p[ j+1 ]

#include<iostream>
#define N 10010
#define M 100010

using namespace std;

int main()
{
	int n, m;
    	char s[M], p[N];
 	int ne[N];
	 
	cin >> n >> p+1 >> m >> s+1;
 
 	for(int i = 2, j = 0; i <= n; i++) //求出 next[]
 	{
  		while(j && p[i] != p[j+1])
   			j = ne[j];
		if(p[i] == p[j+1])
   			j++;
 		ne[i] = j;
 	}
 	
 	for(int i = 1, j = 0; i <= m; i++) //KMP算法
 	{
 		while(j && s[i] != p[j+1])
   			j = ne[j];
  		if(s[i] == p[j+1])
  			 j++;
  		if(j == n)
  		{
   			printf("%d ", i-n);
   			j = ne[j];
 		 }
 	}
	return 0;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值