Busca em texto com o método de Boyer Moore
Publicado por Danilo Azevedo em 23/07/2014
[ Hits: 6.341 ]
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
Softwares para uso em modo texto do Linux
Postfix + Gmail no Slackware Linux 12.2
Gedit - Como corrigir erros de acentuação em códigos HTML ou PHP
Ubindows Seven ou Winbuntu 9.10
Papagaiando o XFCE com temas e recursos
WhatsApp com Chamadas no Linux via Waydroid
XFCE - quase um Gnome ou Plasma mas muito mais leve
LXQT - funcional para máquinas pererecas e usuários menos exigentes
Manutenção básica para Gentoo Linux (com script)
Conheça o Zashterminal, um terminal moderno com IA
DOOM Carniceiro: rode o Meatgrinder com uzdoom (Gentoo e Ubuntu)
Samba 4 AD-DC 2026: Como instalar e configurar um Active Directory (via APT-GET)
[Resolvido] Sumiço de redes e micro quedas no iwd/iwgtk (Realtek rtw88)
eu queria saber no lenovo slim, se tem como ver os mhz de memoria e tu... (3)









