String matching with a dynamic pattern

Detalhes bibliográficos
Ano de defesa: 2024
Autor(a) principal: Bruno Maletta Monteiro
Orientador(a): Não Informado pela instituição
Banca de defesa: Não Informado pela instituição
Tipo de documento: Dissertação
Tipo de acesso: Acesso aberto
Idioma: eng
Instituição de defesa: Universidade Federal de Minas Gerais
Programa de Pós-Graduação: Não Informado pela instituição
Departamento: Não Informado pela instituição
País: Não Informado pela instituição
Palavras-chave em Português:
Link de acesso: https://hdl.handle.net/1843/80790
Resumo: Neste trabalho, nós estudamos variações do problema Casamento de Padrões: dadas duas strings, um padrão P e um texto T, queremos computar quantas vezes o padrão ocorre no texto. Nossa contribuição é focada no caso de um padrão dinâmico, ou seja, queremos suportar adição e remoção de caracteres no padrão, e após cada operação computar quantas vezes ele ocorre no texto. Nós mostramos um algoritmo simples usando Suffix Arrays que usa tempo O(log |T|), depois de tempo O(|T|) de pré-processamento. Nós mostramos como estender nossa solução para suportar remoção, transposição (mover a substring para outra posição) e cópia (copiar a substring e colar em uma posição específica) de substrings, na mesma complexidade de tempo. Nossa solução ainda pode ser estendida para suportar um texto online (adicionar caracteres em uma ponta do texto), mantendo as mesmas complexidades amortizadas de tempo. Também fazemos uma análise do tempo de execução do algoritmo proposto contra um algoritmo ingênuo, para demonstrar sua viabilidade. Também é discutida uma generalização do suffix array para várias strings.
id UFMG_b0e5ef5d68e4b5b0191c0eda4002fc3d
oai_identifier_str oai:repositorio.ufmg.br:1843/80790
network_acronym_str UFMG
network_name_str Repositório Institucional da UFMG
repository_id_str
spelling String matching with a dynamic patternCasamento de padrões dinâmicosComputação – TesesAlgoritmos de computador – TesesComplexidade computacional – TesesProcessamento de vetor (Computação) – TesesReconhecimento de padrões – TesesstringsAlgorithmssuffix arraystring matchingNeste trabalho, nós estudamos variações do problema Casamento de Padrões: dadas duas strings, um padrão P e um texto T, queremos computar quantas vezes o padrão ocorre no texto. Nossa contribuição é focada no caso de um padrão dinâmico, ou seja, queremos suportar adição e remoção de caracteres no padrão, e após cada operação computar quantas vezes ele ocorre no texto. Nós mostramos um algoritmo simples usando Suffix Arrays que usa tempo O(log |T|), depois de tempo O(|T|) de pré-processamento. Nós mostramos como estender nossa solução para suportar remoção, transposição (mover a substring para outra posição) e cópia (copiar a substring e colar em uma posição específica) de substrings, na mesma complexidade de tempo. Nossa solução ainda pode ser estendida para suportar um texto online (adicionar caracteres em uma ponta do texto), mantendo as mesmas complexidades amortizadas de tempo. Também fazemos uma análise do tempo de execução do algoritmo proposto contra um algoritmo ingênuo, para demonstrar sua viabilidade. Também é discutida uma generalização do suffix array para várias strings.CAPES - Coordenação de Aperfeiçoamento de Pessoal de Nível SuperiorUniversidade Federal de Minas Gerais2025-03-20T15:13:33Z2025-09-08T23:12:29Z2025-03-20T15:13:33Z2024-12-04info:eu-repo/semantics/publishedVersioninfo:eu-repo/semantics/masterThesisapplication/pdfhttps://hdl.handle.net/1843/80790engBruno Maletta Monteiroinfo:eu-repo/semantics/openAccessreponame:Repositório Institucional da UFMGinstname:Universidade Federal de Minas Gerais (UFMG)instacron:UFMG2025-09-08T23:12:29Zoai:repositorio.ufmg.br:1843/80790Repositório InstitucionalPUBhttps://repositorio.ufmg.br/oairepositorio@ufmg.bropendoar:2025-09-08T23:12:29Repositório Institucional da UFMG - Universidade Federal de Minas Gerais (UFMG)false
dc.title.none.fl_str_mv String matching with a dynamic pattern
Casamento de padrões dinâmicos
title String matching with a dynamic pattern
spellingShingle String matching with a dynamic pattern
Bruno Maletta Monteiro
Computação – Teses
Algoritmos de computador – Teses
Complexidade computacional – Teses
Processamento de vetor (Computação) – Teses
Reconhecimento de padrões – Teses
strings
Algorithms
suffix array
string matching
title_short String matching with a dynamic pattern
title_full String matching with a dynamic pattern
title_fullStr String matching with a dynamic pattern
title_full_unstemmed String matching with a dynamic pattern
title_sort String matching with a dynamic pattern
author Bruno Maletta Monteiro
author_facet Bruno Maletta Monteiro
author_role author
dc.contributor.author.fl_str_mv Bruno Maletta Monteiro
dc.subject.por.fl_str_mv Computação – Teses
Algoritmos de computador – Teses
Complexidade computacional – Teses
Processamento de vetor (Computação) – Teses
Reconhecimento de padrões – Teses
strings
Algorithms
suffix array
string matching
topic Computação – Teses
Algoritmos de computador – Teses
Complexidade computacional – Teses
Processamento de vetor (Computação) – Teses
Reconhecimento de padrões – Teses
strings
Algorithms
suffix array
string matching
description Neste trabalho, nós estudamos variações do problema Casamento de Padrões: dadas duas strings, um padrão P e um texto T, queremos computar quantas vezes o padrão ocorre no texto. Nossa contribuição é focada no caso de um padrão dinâmico, ou seja, queremos suportar adição e remoção de caracteres no padrão, e após cada operação computar quantas vezes ele ocorre no texto. Nós mostramos um algoritmo simples usando Suffix Arrays que usa tempo O(log |T|), depois de tempo O(|T|) de pré-processamento. Nós mostramos como estender nossa solução para suportar remoção, transposição (mover a substring para outra posição) e cópia (copiar a substring e colar em uma posição específica) de substrings, na mesma complexidade de tempo. Nossa solução ainda pode ser estendida para suportar um texto online (adicionar caracteres em uma ponta do texto), mantendo as mesmas complexidades amortizadas de tempo. Também fazemos uma análise do tempo de execução do algoritmo proposto contra um algoritmo ingênuo, para demonstrar sua viabilidade. Também é discutida uma generalização do suffix array para várias strings.
publishDate 2024
dc.date.none.fl_str_mv 2024-12-04
2025-03-20T15:13:33Z
2025-09-08T23:12:29Z
2025-03-20T15:13:33Z
dc.type.status.fl_str_mv info:eu-repo/semantics/publishedVersion
dc.type.driver.fl_str_mv info:eu-repo/semantics/masterThesis
format masterThesis
status_str publishedVersion
dc.identifier.uri.fl_str_mv https://hdl.handle.net/1843/80790
url https://hdl.handle.net/1843/80790
dc.language.iso.fl_str_mv eng
language eng
dc.rights.driver.fl_str_mv info:eu-repo/semantics/openAccess
eu_rights_str_mv openAccess
dc.format.none.fl_str_mv application/pdf
dc.publisher.none.fl_str_mv Universidade Federal de Minas Gerais
publisher.none.fl_str_mv Universidade Federal de Minas Gerais
dc.source.none.fl_str_mv reponame:Repositório Institucional da UFMG
instname:Universidade Federal de Minas Gerais (UFMG)
instacron:UFMG
instname_str Universidade Federal de Minas Gerais (UFMG)
instacron_str UFMG
institution UFMG
reponame_str Repositório Institucional da UFMG
collection Repositório Institucional da UFMG
repository.name.fl_str_mv Repositório Institucional da UFMG - Universidade Federal de Minas Gerais (UFMG)
repository.mail.fl_str_mv repositorio@ufmg.br
_version_ 1856414126092320768