#include <stdio.h>
#include <string.h>
#include <stdlib.h>
//应用场景:模糊查询
//用kmp算法,检测父串中是否包含子串,包含则返回1,不包含返回0
int kmpContains(char *father,char *son) {
int length = strlen(son);
//prefix是匹配模式数组
int *prefix = (int *)malloc(length*sizeof(int));
//开始计算 prefix数组
prefix[0]=0;
int k = 0,i;//前缀的长度
for(i=1; i<length; i++) {
while(k>0&&son[k]!=son[i]) k=prefix[k-1];
if(son[k]==son[i]) k=k+1; //说明p[0...k-1]共k个都匹配了
prefix[i]=k;
}
//开始匹配
int point=0;
for(i=0; i<=strlen(father); i++) {
while(point!=0&&(father[i]!=son[point])) {
point = prefix[point-1];
}
if(father[i]==son[point]) {
point++;
if(point == length) {
//printf("找到了,坐标为:%d \n",i-point+1);
return 1;
}
}
}
//未找到
return 0;
}
//测试
int main() {
char father[20] = "15151515526";
char son[20] = "15155";
printf("1表示找到,0表示未找到,结果:%d \n",kmpContains(father,son));
char son2[20] = "5526";
printf("1表示找到,0表示未找到,结果:%d \n",kmpContains(father,son2));
}
11-03
3万+
![](https://csdnimg.cn/release/blogv2/dist/pc/img/readCountWhite.png)
“相关推荐”对你有帮助么?
-
非常没帮助
-
没帮助
-
一般
-
有帮助
-
非常有帮助
提交