
【问题描述】KMP算法是字符串模式匹配算法中较为高效的算法之一,其在某次子串匹配母串失败时并未回溯母串的指针而是将子串的指针移动到相应的位置。
【输入形式】3组字符串,每组字符串占一行。
每行包含由空格分隔的两个字符串,字符串仅由英文小写字母组成且长度不大于100。
【输出形式】每组数据输出1行,输出后一个字符串在前一个字符串中的位置,如果不匹配,则输出0。
【样例输入】
string str
thisisalongstring isa
nosubstring subt
【样例输出】
1
5
0
【提示】表示字符串的数据结构可以是字符数组或用串类实现。
KMP算法调用很简单,但难的是理解算法的思想。
掌握算法的思想才能说是掌握算法。
#include
#include
#define maxsize 200
using namespace std;
struct lsystring
{
char data[maxsize];
int len;
};
void getnext(lsystring lsy,int next[])
{
int j=0,k=-1;
next[0]=-1;
while(j=lsy2.len)
cout<>s1>>s2)
{
lsy1.len=s1.length();
lsy2.len=s2.length();
s1.copy(lsy1.data,lsy1.len,0);
*(lsy1.data+lsy1.len)='\0';
s2.copy(lsy2.data,lsy2.len,0);
*(lsy2.data+lsy2.len)='\0';
KMPindex(lsy1,lsy2);
}
return 0;
}
KMP算法详解请看:数据结构KMP算法配图详解(超详细)_哈顿之光的博客-CSDN博客_数据结构kmp算法
强推这篇文章,讲解细致,图片直观,通俗易懂。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)