Busca em texto com o método de Boyer Moore
Publicado por Danilo Azevedo em 23/07/2014
[ Hits: 6.196 ]
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
Rádio UOL com proxy transparente
Bradesco NetEmpresa no CentOS 7 64 bit (Firefox 64 bit + Java 64 bit)
IA Turbina o Desktop Linux enquanto distros renovam forças
Como extrair chaves TOTP 2FA a partir de QRCODE (Google Authenticator)
Linux em 2025: Segurança prática para o usuário
Desktop Linux em alta: novos apps, distros e privacidade marcam o sábado
IA chega ao desktop e impulsiona produtividade no mundo Linux
Atualizando o Fedora 42 para 43
Como saber se o seu e-mail já teve a senha vazada?
Como descobrir se a sua senha já foi vazada na internet?
Programa fora de escala na tela do pc (33)
Eu queria adicionar a incon do wifi e deixa transparente no fluxbox no... (0)









