Voltar

Knuth-Morris-Pratt - Strings

0 Curtidas
int pi[MAXSZ], res[MAXSZ], nres;

void morris_pratt(string text, string pattern) {
    nres = 0;
    pi[0] = -1;
    for(int i = 1; i < pattern.size(); ++i) {
        pi[i] = pi[i-1];
        while(pi[i] >= 0 && pattern[pi[i] + 1] != pattern[i])
            pi[i] = pi[pi[i]];
        if(pattern[pi[i] + 1] == pattern[i]) ++pi[i];
    }

    int k = -1; //k + 1 eh o tamanho do match atual
    for(int i = 0; i < text.size(); ++i) {
        while(k >= 0 && pattern[k + 1] != text[i])
            k = pi[k];
        if(pattern[k + 1] == text[i]) ++k;
        if(k + 1 == pattern.size()) {
            res[nres++] = i - k;
            k = pi[k];
        }
    }
}
Problemas relacionados
  Nome Comentário
Ainda não há nenhum problema relacionado a esse conteúdo

Comentários


Postagens neste fórum só são permitidas para membros com conta ativa. Por favor, efetue login or cadastro para postar.