1、BF算法
BF算法,即暴力(Brute Force)算法,是普通的模式匹配算法,BF算法的思想就是将目标串S的第一个字符与模式串T的第一个字符进行匹配,若相等,则继续比较S的第二个字符和 T的第二个字符;若不相等,则比较S的第二个字符和T的第一个字符,依次比较下去,直到得出最后的匹配结果。BF算法是一种蛮力算法。
2、C语言实现
#include<stdio.h>
#include<assert.h>
#include<string.h>
/*
str主串
sub字串
返回值:返回子串在主串当中的下标。如果不存在返回-1
*/
int BF(char* str, char* sub)
{
assert(str != NULL && sub != NULL);
if (str == NULL || sub == NULL)
return -1;
int lenStr = strlen(str);
int lenSub = strlen(sub);
int i = 0,j = 0;
while (i < lenStr && j < lenSub)
{
if (str[i] == sub[j])
{
i++;
j++;
}
else
{
i = i - j + 1;
j = 0;
}
}
if (j >= lenSub)//字串遍历完
return i - j;
return -1;
}
int main()
{
printf("%d\n", BF("abababc", "abc"));
return 0;
}