KMP算法C语言实现。弄了好久才搞好。。。
来源:互联网 发布:硬件和软件是什么 编辑:程序博客网 时间:2024/06/09 20:03
// KMP算法
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
void get_next(char *T,int next[])//修正前的next数组
{
int i = 1,j = 0;
next[0] = -1;
next[1] = 0;
int m = strlen(T);
while(i<strlen(T)-1)
{
if(j == -1||T[j]==T[i])
{
++i;
++j;
next[i] = j;
}
else j = next[j];
}
}
void get_nextval(char *T,int nextval[])//修正后的nextval数组
{
int i = 1,j = 0;
nextval[0] = -1;
nextval[1] = 0;
int m = strlen(T);
while(i<strlen(T)-1)
{
if(j == -1||T[j]==T[i])
{
++i;
++j;
if(T[i]!=T[j]) nextval[i] = j;
else nextval[i] = nextval[j];
}
else j = nextval[j];
}
}
int Index_kmp(char *S,char *T,int pos,int next[])//逐项比较
{
int j = 0,i = pos,lens=strlen(S),lent=strlen(T);
get_next(T,next);
while(i<lens&&j<lent)
{
if(S[i]==T[j]||j==-1)
{
i++;j++;
}
else j = next[j];
}
if(j>=lent) return i-lent;
else return -1;
}
int main()
{
char *S="adbadabbaabadabbadada",*T="adabbadada";
int m;
int *next = (int *)malloc((strlen(T)+1)*sizeof(int));//修正前的next数组
int *nextval = (int *)malloc((strlen(T)+1)*sizeof(int));//修正后的nextval数组
get_next(T,next);
printf("修正前next数组为:");
for(m = 0;m<strlen(T);m++)
{
printf("%d ",next[m]+1);
}
get_nextval(T,nextval);
printf("\n修正后的nextval数组为:");
for(m=0;m<strlen(T);m++)
{
printf("%d ",nextval[m]+1);
}
int t = Index_kmp(S,T,0,nextval);
if(t==-1) printf("\n无匹配项!\n");
else
{
printf("\n在第%d项开始匹配成功\n",t+1);
}
return 0;
}
- KMP算法C语言实现。弄了好久才搞好。。。
- KMP算法C语言实现。弄了好久才搞好。。。
- KMP算法c语言实现
- KMP算法--c语言实现
- KMP算法实现才 c++
- KMP算法的C语言代码实现
- KMP字符串匹配算法C语言实现
- KMP算法的C语言实现
- KMP算法C语言的实现
- 模式匹配 KMP C语言算法实现
- KMP算法-C语言程序实现
- KMP算法的C语言实现
- KMP算法的C语言实现
- kmp算法字符串匹配C语言实现
- C语言实现字符串匹配KMP算法
- C语言KMP算法的实现
- C语言实现KMP模式匹配算法
- KMP算法的C语言代码实现
- 三级联动地址选择器,遇到的问题记录
- 2015年09月12日
- 《越狱》观后感
- (转)KMP算法实现。超级赞!见过的最容易理解的
- opencv实现车牌识别之字符分割
- KMP算法C语言实现。弄了好久才搞好。。。
- (转)经验分享:CSS浮动(float,clear)通俗讲解
- Redis 安装 启动 连接 配置 重启
- 存储过程4
- jquery的html,text,val
- html5的video标签测试应用
- python复习。知识点小记
- li浮动时ul高度为0,解决ul自适应高度的几种方法
- 清除浮动(clearfix hack)