Brute-Force算法简称BF算法,即暴风(Brute Force)算法,是普通的模式匹配算法,BF算法的思想就是将目标串S的第一个字符与模式串T的第一个字符进行匹配,若相等,则继续比较S的第二个字符和 T的第二个字符;若不相等,则比较S的第二个字符和T的第一个字符,依次比较下去,直到得出最后的匹配结果。
BF算法是一种蛮力算法。
#include<string>
int Brute_Force(string S, string T)
{
unsigned int i = 0;
unsigned int j = 0;
int pos = -1;
while (i < S.length()&&j < T.length()) { // 循环比较的条件
if (S[i] == T[j]) {// 如果相等 则继续比较
i++;
j++;
}
else { // 不相等则让指向主串的“移动指针”i回溯,让指向模式串的“移动指针”j指向初始位置0
i = i - (j - 1); // 主串的“移动指针”i应该回溯(i-1)个单位
j = 0;
}
}
// 如果j>=T.length() 则说明匹配成功 那么修改pos
if (j >= T.length()) {
pos = i - T.length();
return pos;
}
else {// 否则直接-1
return -1;
}
}