估计没几个人能看懂我的KMP算法了,搞得有点复杂,有蛮多注释

本文深入探讨了KMP算法的实现过程,包括模式串的next数组计算和主串匹配,详细展示了如何通过该算法高效地进行字符串匹配。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

//KMP算法实现
#include <iostream>
#include <string>
using namespace std;
//我承认KMP算法我搞得逻辑太复杂了
void KMP(char* a,char* b){
	int next[10]={1};
	int i,j,count1,count2,flag=1;
	//计算模式串b的next[j]
    next[0]=0;//如果第一位出错
    next[1]=1;//如果第二位出错
	//count1为左边的计数,count2为右边的计数
    for(j=2;j<strlen(b);j++){
       for(i=0;i<j;i++){
		   count1=i;
		   count2=1;
		   flag=1;
		   while(count1!=-1){
			   if(b[count1]==b[j-count2] && (count1!=j-count2))
				   flag++;
			   else
				   flag=1;
			   count1--;
			   count2++;
		   }
		   //flag为记号,如果有j能变得更大,那么赋值给next[j]
		   if(flag>next[j])
			   next[j]=flag;
	   }
	}

	//输出next[j]矩阵
	for(int x=0;x<strlen(b);x++)
		cout<<next[x]<<endl;
	//主串和模式串进行匹配
	i=j=0;
	while(i<strlen(a)){
		if(j==strlen(b)){
			cout<<"找到匹配"<<endl;
			return;
		}
		if(a[i]==b[j]){
			i++;
			j++;
		}
		else{
			j=next[j];
		    if(j==0)
				i++;
			else 
				j--;
		}
	}
	cout<<"未找到匹配"<<endl;
}

void main()
{
	char a[]="ababex";
	char b[]="abab";
	KMP(a,b);
	system("pause");
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值