c语言编写kmp算法,KMP算法 纯C实现

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼

我自己写的KMP算法:

int nt[256];

void get_next1(char* T, int next[], int tlen)

{

int i = 0;

int j = 1;

next[0] = -1;

while( j 

{

if ( T[i] == T[j]  )

{

next[j] = 0;

i++;

}

else

{

next[j] = i;

i = 0;

}

j++;

}

}

int Index_KMP1(char* S, char* T,int slen, int tlen)

{

int i=0, j=0;

while( j 

{

if( j==-1 || S[i] == T[j] )

{

i++; j++;

}

else

{

j = nt1[j];

}

}

if( j == tlen )

{

return i-j;

}

else

{

return -1;

}

}

int main(int argc, char* argv[])

{

char ch[] = "aaaaa";

int len = (int)strlen(ch);

get_next1(ch, nt1, len);

for(int i=0; i

{

printf("%d[%c]=%d\n", i, ch[i], nt1[i]);

}

char sch[] = "abaavaaaaaab";

//char sch[] = "aawsdvddfabcdabceabcdfdwdasd";

int slen = (int)strlen(sch);

int ret = Index_KMP1(sch, ch, slen, len);

if(ret != -1)

{

char* tmp = sch + ret;

printf("%d, %s\n", ret, tmp);

}

else

printf("not find\n");

return 0;

}

我发现在数据结构的书中,用的SString类型,它的第一位是该字符的长度,所以和我们平时所需要的KMP算法不太兼容。

有什么问题,可以发到我的邮箱:bobyuworker@126.com

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值