KMP 算法 C++
2015-06-04 09:52
232 查看
#include <iostream>
#include<string.h>
#include<stdio.h>
using namespace std;
void Compute_Prefix(string p,int prefix[],int length)
{
int k=0;
prefix[0]=0;
for(int i=1;i<length;i++)
{
while(k>0&&p[i]!=p[k])
{
k=prefix[k-1];
}
if(p[k]==p[i])
{
k=k+1;
}
prefix[i]=k;
}
}
void KMP_Matcher(string P,string T)
{
int length_P=P.length();
int length_T=T.length();
int i,q=0;
int* prefix=new int[length_P];
Compute_Prefix(P,prefix,length_P);
for(i=0;i<length_T;i++)
{
while(q>0&&P[q]!=T[i])
{
q=prefix[q-1];
}
if(P[q]==T[i])
{
q=q+1;
}
if(q==length_P)
{
cout<<(i-length_P+1)<<endl;
q=prefix[q-1];
}
}
}
int main(int argc, char *argv[])
{
string stra="AABA";
string strb="AABAACAADAABAAABAA";
KMP_Matcher(stra,strb);
return 0;
}
#include<string.h>
#include<stdio.h>
using namespace std;
void Compute_Prefix(string p,int prefix[],int length)
{
int k=0;
prefix[0]=0;
for(int i=1;i<length;i++)
{
while(k>0&&p[i]!=p[k])
{
k=prefix[k-1];
}
if(p[k]==p[i])
{
k=k+1;
}
prefix[i]=k;
}
}
void KMP_Matcher(string P,string T)
{
int length_P=P.length();
int length_T=T.length();
int i,q=0;
int* prefix=new int[length_P];
Compute_Prefix(P,prefix,length_P);
for(i=0;i<length_T;i++)
{
while(q>0&&P[q]!=T[i])
{
q=prefix[q-1];
}
if(P[q]==T[i])
{
q=q+1;
}
if(q==length_P)
{
cout<<(i-length_P+1)<<endl;
q=prefix[q-1];
}
}
}
int main(int argc, char *argv[])
{
string stra="AABA";
string strb="AABAACAADAABAAABAA";
KMP_Matcher(stra,strb);
return 0;
}
相关文章推荐
- C++临时对象
- C语言printf和scanf的使用
- C语言基础
- c++ primer 学习笔记(2)迭代器
- C++实现页码数字统计
- String类的实现 三大复制控制函数(C++笔试题 )
- 【深度探索C++对象模型读书笔记】【第3章】Data语意学
- 【深度探索C++对象模型读书笔记】【第3章】Data语意学
- C语言常量变量
- Halcon导出的cpp, VC++环境配置
- QML和C++混合编程--在C++应用程序中使用QML
- C语言数据类型
- C语言简介
- [c++]基类对象作为函数参数(赋值兼容规则)
- C++学习笔记:类
- chapter10test3
- 《c++ primer》 第五版 第二章 笔记
- C++利用宏动态命名变量名
- C/C++语言统计文件中单词出现个数
- c语言一起学习之建立头文件