Função HASH em C++
Publicado por José Cleydson Ferreira da Silva (última atualização em 09/03/2010)
[ Hits: 12.637 ]
Homepage: geminivirus.org
Essa é uma simples introdução a estruturação de dados que faz um simples HASH com complexidade O(n) - int h(string nome) -, seu resultado é apurar o número de colisão.
Para compilá-lo basta usar o compilador g++ da seguinte forma:
$ g++ teste-1.cpp -o teste-1.exe
$ ./teste-1.exe
#include <iostream>
#include <string>
using namespace std;
struct Pessoa
{
string nome;
int colisao;
};
char alfabeto[] = {'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','x','z','w','y'};
string lerNome()
{
string nome;
cout << "informe o proximo nome: " << endl;
cin >> nome;
if (nome == "")
{
cout << "Nome não pode ser vazio: " << endl;
return "";
}
return nome;
}
int h(string nome)
{
char letra;
int soma = 0;
int somaFim = 0;
for(int n=0; n < 15 ; n++)
{
letra = nome[n];
for (int i=0; i<=40; i++)
{
if(letra == alfabeto[i])
{
soma = i + 43;
break;
};
};
somaFim += soma;
};
somaFim = somaFim * 3;
somaFim *= somaFim;
return somaFim % 7;
}
Pessoa* inicializarColisoes()
{
Pessoa *pessoas = new Pessoa[7];
for (int i=0; i<7; i++)
{
pessoas[i].nome = "";
pessoas[i].colisao = 0;
}
return pessoas;
}
void mostrarColisoes(Pessoa *pessoas)
{
for (int i = 0; i<7; i++)
{
// if (pessoas[i].nome == "")
// break;
cout<<"Posição " << i << endl;
cout<<"Colisões " << pessoas[i].colisao << endl << endl;
}
}
int main()
{
Pessoa *p = new Pessoa[7];
p = inicializarColisoes();
int tam; //define o tamanho da palavra para n�o ser preciso ir at� o final da palavra
int somaLetra;
string nome;
int valorHash;
char sair = 'n';
while (sair != 's' )
{
nome = lerNome();
if (nome == "")
continue;
valorHash = h(nome);
cout<<"Valor Hash: "<<valorHash<<endl;
if (p[valorHash].nome != "")
{
p[valorHash].colisao++;
}
p[valorHash].nome = nome;
cout << "Deseja sair?" << endl;
cin >> sair;
}
mostrarColisoes(p);
return 0;
}
Ordenar um lista estática sequencial básica (bubblesort)
Nenhum comentário foi encontrado.
KDE Plasma - porque pode ser a melhor opção de interface gráfica
Gentoo: detectando impressoras de rede e como fixar uma impressora por IP
Como o GNOME conseguiu o feito de ser preterido por outras interfaces gráficas
Por que sua empresa precisa de uma PKI (e como automatizar EMISSÕES de certificados via Web API)
Instalando NoMachine no Gentoo com Systemd (acesso Remoto em LAN)
Instalar Linux em notebook Sony Vaio VPCEG13EB (13)
Vou destruir sua infância:) (7)
Interface gráfica com problema (0)









