如何工作Bitap算法?

时间:2016-11-29 16:21:22

标签: php string algorithm search matching

我试图理解用于字符串匹配的算法Bitap 以下代码与使用PHP语言编写的bitap算法有关:

function SearchString($text, $pattern)
{
$m = strlen($pattern);
$textLen = strlen($text);
$patternMask = array();
$i;

if (empty($pattern)) return 0;
if ($m > 31) return -1; //Error: The pattern is too long!

$R = ~1;

for ($i = 0; $i <= 127; ++$i)
    $patternMask[$i] = ~0;

for ($i = 0; $i < $m; ++$i)
    $patternMask[ord($pattern[$i])] &= ~(1 << $i);

for ($i = 0; $i < $textLen; ++$i)
{
    $R |= $patternMask[ord($text[$i])];
    $R <<= 1;

    if (0 == ($R & (1 << $m)))
        return ($i - $m) + 1;
}

return -1;
}

请解释此代码的工作原理?

我不明白这一部分:

for ($i = 0; $i < $m; ++$i)
$patternMask[ord($pattern[$i])] &= ~(1 << $i);

for ($i = 0; $i < $textLen; ++$i)
{
$R |= $patternMask[ord($text[$i])];
$R <<= 1;

if (0 == ($R & (1 << $m)))
    return ($i - $m) + 1;
}

return -1;

感谢

0 个答案:

没有答案