Pesquisa Binária
Publicado por Enzo de Brito Ferber 31/05/2008
[ Hits: 10.814 ]
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;
}
EXPRESSÕES ARITMÉTICAS - PARTE 1
Nenhum comentário foi encontrado.
Maquina modesta - a vez dos navegadores ferrarem o usuario
Fscrypt: protegendo arquivos do seu usuário sem a lentidão padrão de criptograr o disco
Faça suas próprias atualizações de pacotes/programas no Void Linux e torne-se um Contribuidor
Como rodar o Folding@home no Linux
Criando um painel de controle (Dashboard) para seu servidor com o Homepage
Calculadoras online gratuitas para o dia a dia do usuário Linux
Utilizando a Ferramenta xcheckrestart no Void Linux
Pisando no acelerador do Linux Mint: Kernel XanMod, zRAM e Ajustes de Swap
Meu kde connect não funciona no debian (1)
Warsaw não é reconhecido no Google Chrome 147.0.7727.55 (0)









