博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
KMP代码(转载)
阅读量:6146 次
发布时间:2019-06-21

本文共 2145 字,大约阅读时间需要 7 分钟。

/*

原作者: glq2000
/*
参考资料:
*/

#include 
#include
char a[] = "abababaababacb"; char b[] = "ababacb"; //P[0]不使用,P[i]表示B串的前i个字符中, 前P[i]个字符和后P[i]个字符相同 int P[7]; //尽管strlen(b)为7,但P[7]用不到,只用P[1]到P[6] char* KMP(char* A, char* B); //返回B串在A串中的位置 B串:模式串 A串:待匹配串 void InitP(char *B); //将B串(模式串)进行自我匹配 int main() { InitP(b); char *idx = KMP(a, b); if(!idx) puts("b is not a's substring."); else printf("b is a's substring, the index is %d/n",idx-a); getchar(); return 0; } char* KMP(char *A, char *B) { int len1=strlen(A), len2=strlen(B); int i, j=0; //j代表目前B串中已与A串匹配了的字符的个数 for(i=0; i
0 && A[i]!=B[j]) //0...j-1,已匹配了j个字符,sub[j]是sub的第j+1的字符,因为下标从0开始 j = P[j]; if(A[i] == B[j]) ++j; if(j == len2) //当j(B中已匹配了的字符串的个数)与B串本身长度相等时,说明匹配完毕 return A+i-j+1; //此时可计算出指针位置 } return NULL; } /***************************************************************************** 初始化数组P[7],P[i]表示B串的前i个字符中, 前P[i]个字符和后P[i]个字符相同 比如: char b[] = "ababacb"; p[1]=0 P[2]=0, 因为字符串b[]的前2个字符"ab"不符合条件. P[3]=1, 因为字符串b[]的前3个字符"aba",其第一个字符和最后一个字符相同 P[4]=2, 因为字符串b[]的前4个字符"abab",其前两个字符和后两个字符相同 P[5]=3, 因为字符串b[]的前5个字符"ababa",其前3个字符和后3个字符相同,都是aba P[6]=0 函数InitP(char *B)的任务就是根据B串初始化数组P,这其实就是一个对B串进行自我匹配 的过程,与上面的KMP(char *A, char *B)函数很像. *******************************************************************************/ void InitP(char *B) { P[0] = 0; P[1] = 0; int i, j=0, len=strlen(B); for(i=2; i
0 && B[j]!=B[i-1]), 这里的j代表 在比较第i个字符(从1开始数)和B[j]时,前i-1个字符中的前j个字符和后j的字符相同 B[j]代表第j的字符(从1开始数)的下一个字符*/ while(j>0 && B[j]!=B[i-1]) //如果第i个字符和第j个字符的下一个字符(即B[j])不同,则改变j的值,再重新比较 j = P[j]; if(B[j] == B[i-1]) ++j; P[i] = j; } }

转载于:https://www.cnblogs.com/moon13579/p/8652707.html

你可能感兴趣的文章
Spring Boot 整合Spring Security 和Swagger2 遇到的问题小结
查看>>
[20170628]12C ORA-54032.txt
查看>>
除以2
查看>>
高可用集群原理解析
查看>>
Nginx配置URL转向tomcat
查看>>
极客Web前端开发资源大荟萃#001
查看>>
让div固定在某个位置
查看>>
Java开发环境Docker镜像
查看>>
从无到有,WebService Apache Axis2初步实践
查看>>
任务调度(一)——jdk自带的Timer
查看>>
UIKit框架(15)PCH头文件
查看>>
整理看到的好的文档
查看>>
Linux磁盘管理和文件系统管理
查看>>
linux运维人员的成功面试总结案例分享
查看>>
Windows DHCP Server基于MAC地址过滤客户端请求实现IP地址的分配
查看>>
命令查询每个文件文件数
查看>>
《跟阿铭学Linux》第8章 文档的压缩与打包:课后习题与答案
查看>>
RAC表决磁盘管理和维护
查看>>
Apache通过mod_php5支持PHP
查看>>
发布一个TCP 吞吐性能测试小工具
查看>>