数据结构 BF算法

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了数据结构 BF算法相关的知识,希望对你有一定的参考价值。

int Index (SString S , SString T , int pos)
i=pos;
j=1;
while(i<=S[0]&&j<=T[0]) // S[0]、T[o]是什么意思呢??
if(S[i]==t[j]) ++i,++j; // 为什么是++i,而不是i++??
else i=i-j+2;j=1;

if (j>T[0]) return i-T[0]; //这条语句是什么意思呢??
else return 0;

建议动手画一画会比较直观
i,j是这里作位置指针 i指向SString S中的一个位置 j指向SString T的一个位置
while后的括号中是循环继续的条件
很多地方字符串本身可以理解成一个字符构成的数组
S[0]这里指0号位置的内容 这里用既然用i,j和这个0#内容比较来确定何时结束循环
即可以把0号位置的内容理解为i最终的移动位置 j同理
这里++i和i++皆可 先加后加不影响 因为本句里已经没有再用到i的值了
最后一句 如果j>T[0]导致循环结束,此时返回i,这里i是一个在S中移动最终位置
与T[0]的差 相当于两个最终位置间的距离
另外 一般用return 0 表示正常返回

强烈建议动手画 文字表述不能很直观
参考技术A S[0]、T[o]是什么意思呢??

是数组。
if (j>T[0]) return i-T[0]; //这条语句是什么意思呢??

如果:j大于T[0],就返回:i-T[0]
参考技术B T[0],S[0]表示串的长度,++i,++j,C语言的表示方式,如果比较的两个相同,就都加一,先加再赋给i,j , if那句表示模式串比较完后,返回模式串T在S中的位置之后

数据结构串---BF算法(朴素模式匹配)

(一)BF算法了解

BF算法,即暴风(Brute Force)算法,是普通的模式匹配算法。
BF算法的思想就是将目标串S的第一个字符与模式串T的第一个字符进行匹配,若相等,则继续比较S的第二个字符和 T的第二个字符;
若不相等,则比较S的第二个字符和T的第一个字符,依次比较下去,直到得出最后的匹配结果。BF算法是一种蛮力算法。

(二)算法模拟

技术分享图片

开始匹配:

技术分享图片

第一次匹配:H和L不相等,串S向下移一个,串T回到原位置

技术分享图片

第二次匹配:L和O不相等,串S移向下一个位置,串T回到原位

技术分享图片

第三次匹配:L和L匹配上了,此位置记为A,串S移向下一个位置,串T也移向下一个位置,继续匹配

技术分享图片

第四次匹配:L和E不匹配,将串S移动到标记为A的下一个位置重新进行匹配,将串T回到原位

技术分享图片

第五次匹配:L和L匹配上了,将此位置记为B,串S移向下一个位置,串T也移向下一个位置,继续匹配

技术分享图片

第六次匹配:E和E匹配上了,串S移向下一个位置,串T也移向下一个位置,继续匹配

技术分享图片

第七次匹配:W和W匹配上了,串T全部匹配成功,一次匹配成功。

(三)代码实现:前面我们实现顺序存储串的时候使用的就是BF算法

int Index(String S, String T, int pos)  //返回子串T在主串S中第pos个字符之后的位置,若不存在,返回0
{
    int i, j;
    i = pos;  //用于主串S中当前位置下标,若pos不为1时,则从pos位置开始匹配
    j = 1;   //用于子串T多种当前位置下标值
    while (i<=S[0]-T[0]+1&&j<=T[0])  //若i的长度小于可匹配长度,且j小于T的长度时循环
    {
        if (S[i]==T[j])  //两字符相等时继续匹配
        {
            j++;
            i++;
        }
        else  //指针后退重新匹配
        {
            i = i - j + 2;    //注意这个索引的加2,i退回到上次匹配首位的下一个位置
            j = 1;  //j退回子串T的首位
        }
    }
    if (j > T[0])
        return i - T[0];
    return 0;
}
BF算法也是回溯法

(四)性能分析

S=000000000000000000000000000001
T=0000001
最坏的时间复杂度为O((n-m+1)*m)
在实际运用中,对于计算机来说,处理的都是二进制位的0和1的串,一个字符可以看做8位0/1串,汉字和图片更多,所以当我们使用BF匹配效率就会特别低

 



以上是关于数据结构 BF算法的主要内容,如果未能解决你的问题,请参考以下文章

数据结构与算法动画:什么是 BF 算法 ?

数据结构:BF算法

408数据结构与算法—串和BF算法(二十四)

408数据结构与算法—串和BF算法(二十四)

数据结构和算法学习笔记三:KMP算法

数据结构 BF算法