Busca em texto com o método de Boyer Moore
Publicado por Danilo Azevedo em 23/07/2014
[ Hits: 6.408 ]
1 2 3 4 5 ... 35
String: W H I C H - F I N A L L Y - H A L T S . - - A T - T H A T - P O I N T
1 2 3 4 5 6 7
Padrão: A T - T H A T
Fórmulas (usando o padrão):
-3 -2 -1 0 1 2 3 4 5 6 7
$ $ $ $ A T - T H A T
1
Calcular o delta2(6): procurar o sufixo de A, que não tenha A como prefixo.
-3 -2 -1 0 1 2 3 4 5 6 7
$ $ $ $ A T - T H A T
4 1
Calcular o delta2(5): procurar o sufixo de H, que não tenha tenha H como prefixo.
-3 -2 -1 0 1 2 3 4 5 6 7
$ $ $ $ A T - T H A T
7 4 1
Calcular o delta2(4): procurar sufixo de T, que não tenha T como prefixo.
-3 -2 -1 0 1 2 3 4 5 6 7
$ $ $ $ A T - T H A T
8 7 4 1
Calcular o delta2(3): ...
-3 -2 -1 0 1 2 3 4 5 6 7
$ $ $ $ A T - T H A T
T H A T
E portanto, o T H A T no índice -1
-3 -2 -1 0 1 2 3 4 5 6 7
$ $ $ $ A T - T H A T
9 8 7 4 1
Calcular o delta2(2) e delta2(1): dá trabalho.
-3 -2 -1 0 1 2 3 4 5 6 7
$ $ $ $ A T - T H A T
11 10 9 8 7 4 1
Utilizando delta1 e delta2 para achar o padrão:
1 2 3 4 5 ... 35 W H I C H - F I N A L L Y - H A L T S . - - A T - T H A T - P O I N T A T - T H A TF não ocorre no padrão, logo, delta1(F) = 7
1 2 3 4 5 ... 35
W H I C H - F I N A L L Y - H A L T S . - - A T - T H A T - P O I N T
A T - T H A T
A T - T H A T
Os caracteres não batem (não utiliza delta2), utilizamos o delta1 do caractere encontrado, delta1(-) = 4:
1 2 3 4 5 ... 35
W H I C H - F I N A L L Y - H A L T S . - - A T - T H A T - P O I N T
A T - T H A T
A T - T H A T
A T - T H A T
|
Os caracteres batem (T e T), utilizamos o máximo entre delta1 e delta2. o sufixo é o T (paramos no A)
1 2 3 4 5 ... 35
W H I C H - F I N A L L Y - H A L T S . - - A T - T H A T - P O I N T
A T - T H A T
A T - T H A T
A T - T H A T
A T - T H A T
|
Os caracteres batem até o caractere A, logo, utilizamos o delta2 que tem sufixo A T (o delta2(5)= 7).
1 2 3 4 5 ... 35
W H I C H - F I N A L L Y - H A L T S . - - A T - T H A T - P O I N T
A T - T H A T
A T - T H A T
A T - T H A T
A T - T H A T
A T - T H A T
Instalando o wifi (Realtek 8187b) no Kubuntu 8.04
Instalando Xdebug no Ubuntu/Mint no PHP 7
Oracle PL/Web em versão Open Source com PHP e PostgreSQL
Lançada a 3ª edição da revista PHP Magazine
Amarrando placas de rede ao endereço MAC
Faça suas próprias atualizações de pacotes/programas no Void Linux e torne-se um Contribuidor
Como rodar o Folding@home no Linux
Criando um painel de controle (Dashboard) para seu servidor com o Homepage
O Abismo entre o Código e o Chão: Saltos Tecnológicos e a Exclusão Estrutural no Brasil
Instalar e Configurar a santíssima trindade (PAP) no Void Linux
Pisando no acelerador do Linux Mint: Kernel XanMod, zRAM e Ajustes de Swap
Como compilar kernel no Linux Mint
Lançamento do Brutal DOOM test 6
Consertando o erro no Brave de webgl
Solução para ter de volta as bordas e barra de títulos das janelas em zenity no Debian 13.x
Seno, Coseno, Tangente em CLIPPER (0)
Inserir uma URL num arquvo pelo Ubuntu (CLIPPER) (0)
VMWare Player não conecta na rede nem consigo intercambiar arquivos (1)









