KMP 算法实例详解
2017-07-27 10:47
399 查看
KMP 算法实例详解
KMP算法,是由Knuth,Morris,Pratt共同提出的模式匹配算法,其对于任何模式和目标序列,都可以在线性时间内完成匹配查找,而不会发生退化,是一个非常优秀的模式匹配算法。
分析:KMP模板题、KMP的关键是求出next的值、先预处理出next的值、然后一遍扫过、复杂度O(m+n)
实例代码:
#include<stdio.h> #include<string.h> #define N 1000005 int s ; int p ; int next ; int m,n; void getnext(){ int j=0,k=-1; next[0]=-1; while(j<m){ if(k==-1||p[j]==p[k]){ j++; k++; next[j]=k; } else k=next[k]; } } int kmp(){ int i=0,j=0; getnext(); while(i<n){ if(j==-1||s[i]==p[j]){ i++; j++; } else j=next[j]; if(j==m) return i; } return -1; } int main(){ int t; scanf("%d",&t); while(t--){ scanf("%d%d",&n,&m); for(int i=0;i<n;i++) scanf("%d",&s[i]); for(int i=0;i<m;i++) scanf("%d",&p[i]); if(kmp()==-1) printf("-1\n"); else printf("%d\n",kmp()-m+1); } return 0; }
以上就是KMP 算法的实例详解本站关于数据结构和算法的文章还有很多,希望大家搜索查阅,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
您可能感兴趣的文章:
相关文章推荐
- 一个应用实例详解卡尔曼滤波及其算法实现
- KMP 算法图文详解
- Java随机数算法原理与实现方法实例详解
- 一个应用实例详解卡尔曼滤波及其算法实现
- Python排序搜索基本算法之堆排序实例详解
- Python机器学习k-近邻算法(K Nearest Neighbor)实例详解
- KMP 算法详解
- java 中平方根(sqrt)算法 的实例详解
- 一个应用实例详解卡尔曼滤波及其算法实现
- KMP 算法详解(c语言描述)
- 实例详解卡尔曼滤波及其算法实现
- 使用 Node.js 实现图片的动态裁切及算法实例代码详解
- JavaScript算法系列之快速排序(Quicksort)算法实例详解
- 一个应用实例详解卡尔曼滤波及其算法实现
- 字符串匹配算法-KMP详解
- Java经典算法四十例编程详解+程序实例
- 模式匹配算法KMP详解
- 一个应用实例详解卡尔曼滤波及其算法实现
- KMP匹配算法详解
- javascript常用经典算法实例详解