首页 > 编程语言 > 详细

KMP算法

时间:2019-12-23 21:56:29      阅读:90      评论:0      收藏:0      [点我收藏+]
typedef struct {
	char str[MAX];
	int length;
}SString;

  BF算法

int Index(SString *S, SString *T)
{
	int i, j;
	i = 1; j = 1;
	while (i<=S->length&&j<=T->length)
	{
		if (S->str[i] == T->str[j])
		{
			i++;
			j++;
		}
		else
		{
			i = i - j + 2;
			j = 1;
		}
	}
	if (j > T->length)
		return i - T->length;
	else
		return 0;
}

  KMP算法

int Index_KMP(SString *S, SString *T,int *next)
{
	int i = 1, j = 1;
	while (i <= S->length && j <= T->length)
	{
		if (j == 0 || S->str[i] == T->str[j])
		{
			i++;
			j++;
		}
		else
			j = next[j];
	}
	if (j > T->length)
		return i - T->length;
	else
		return 0;
}

  求next数组

void get_next(SString* S, int *&next)
{
	next=(int *)malloc(sizeof(int)*S->length);
	int i = 1, j = 0;
	next[1] = 0;
	while (i <= S->length)
	{
		if (j == 0 || S->str[i] == S->str[j])
		{
			i++;
			j++;
			next[i] = j; 
		}
		else
			j = next[j];
	}
}

  求nextval数组

void get_nextval(SString*T,int *&nextval)
{
	nextval=(int *)malloc(sizeof(int)*T->length);
	int i = 1, j = 0;
	nextval[1]=0;
	while(i<=T->length)
	{
		if(j==0||T->str[i]==T->str[j])
		{
			i++;j++;
			if(T->str[i]!=T->str[j])
				nextval[i]=j;
			else
				nextval[i]=nextval[j];	
		}
		else
			j=nextval[j];
	}
}

  

KMP算法

原文:https://www.cnblogs.com/KIROsola/p/12088491.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!