Pesquisa Binária
Publicado por Enzo de Brito Ferber 31/05/2008
[ Hits: 10.779 ]
Homepage: http://www.maximasonorizacao.com.br
Este programa ilustra o algoritmo de pesquisa binária, que é o algoritmo de pesquisa mais rápido para dados ordenados (crescente / decrescente).
Espero que ajude alguém algum dia ;)
// binsearch.c
#include <stdio.h>
#include <stdlib.h>
int bin_search (int *vet, int info, int size)
{
int low=0, mid, high=(size - 1);
while (low <= high)
{
mid = (low + high) / 2;
if (vet[mid] == info) return mid;
if (vet[mid] > info) high = mid - 1;
if (vet[mid] < info) low = mid + 1;
}
return (-1);
}
int main (int argc, char **argv)
{
int info, i;
int *vet;
if (argc < 3)
{
printf("Uso: %s <tamanho_vetor> <info>\n", argv[0]);
return 0;
}
// argv[1] >> tamanho do vetor
// argv[2] >> informacao procurada no vetor
vet = (int*) malloc ( atoi(argv[1]) * sizeof(int));
info = atoi(argv[2]);
for (i = 0; i < atoi(argv[1]); i++) *(vet+i) = (i + 1);
printf("Posicao de %d: %d\n", info, bin_search(vet, info, atoi(argv[1]) ));
return 0;
}
gramquilo.c - Transforma grama em quilo
Calcular pagamento com a menor quantidade de cédulas possível
Nenhum comentário foi encontrado.
Cinnamon seria a aposta acertada frente às outras interfaces gráficas mais populares?
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)
Vou destruir sua infância:) (8)
Interface gráfica com problema (2)
Instalar Linux em notebook Sony Vaio VPCEG13EB (13)









