KMP算法

字符串匹配算法,已通过测试 ,原理可以在网上查,按照算法导论里面内容实现。

int strStr(string src, string pattern) {     //主函数
        int rlt = -1;//如果没有找到匹配的,就返回-1
	int sizeSrc = src.size();
	int sizePat = pattern.size();
	if(sizeSrc<sizePat) return -1;
    if(0==sizePat) return 0;
	int* kmpPat = getKMPpattern(pattern);
	int index=0,len = 0;
	while(index<sizeSrc && len<sizePat)
	{
		if(pattern[len]==src[index])
		{
			len++;
			index++;
		}
		else
		{
			if(len==0) index++;
			else len = kmpPat[len-1]+1;
			//if(-1==len) len=0;
		}
	}

	if(len==sizePat) rlt = index-sizePat;
	delete []kmpPat;
	return rlt;
}
int* getKMPpattern(string pattern)    //求取模式函数
{

	int size = pattern.size();
	int *rlt=new int[size];
	if(size==0) return rlt;
	rlt[0]=-1;
	int k=-1;
	for(int i=1;i<size;i++)
	{
		while(k>-1 && pattern[k+1]!=pattern[i])
			k = rlt[k];
		if(pattern[k+1]==pattern[i])
			k++;
		rlt[i]=k;
	}
	return rlt;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值