我是靠谱客的博主 淡然月饼,这篇文章主要介绍BF模式匹配算法,现在分享给大家,希望可以做个参考。

串的堆式顺序存储结构

typedef struct	//串的堆式顺序存储结构
{
char*ch;	//如果是非空串,就按照指定长度分配内存,否则ch指向NULL
int length;
}HString;

BF模式匹配算法

int BFCompare(HString*parent,HString*child,int pos)
{
int i=pos;	//i用于主串parent当前位置下标,若pos不为1,则从pos位置开始匹配
int j=1;	//j用于子串child中当前位置下标
while(i<=parent->length&&j<=child->length)
{
if(parent->ch[i-1]==child->ch[j-1])
{
i++;
j++;
}
else
{
i=i-j+2;	//i回溯到上次匹配首位的下一位
j=1;	//j回溯到子串的首位
}
}
if(j>child->length)
{
return i-child->length;
}
}

最后

以上就是淡然月饼最近收集整理的关于BF模式匹配算法的全部内容,更多相关BF模式匹配算法内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(51)

评论列表共有 0 条评论

立即
投稿
返回
顶部