Pesquisa Binária
Publicado por Enzo de Brito Ferber 31/05/2008
[ Hits: 10.702 ]
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;
}
Passar uma string pra caixa alta.
Calculo de fatorial em C++ com o Qt Creator
Nenhum comentário foi encontrado.
IA Turbina o Desktop Linux enquanto distros renovam forças
Como extrair chaves TOTP 2FA a partir de QRCODE (Google Authenticator)
Linux em 2025: Segurança prática para o usuário
Desktop Linux em alta: novos apps, distros e privacidade marcam o sábado
IA chega ao desktop e impulsiona produtividade no mundo Linux
Como instalar o repositório do DBeaver no Ubuntu
Como instalar o Plex Media Server no Ubuntu
Digitando underscore com "shift" + "barra de espaços"
Como ativar a lixeira e recuperar aquivos deletados em um servidor Linux
Como mudar o nome de dispositivos Bluetooth via linha de comando
Como posso remover arquivos MSG duplicados das minhas pastas de forma ... (0)
Assinador JNLP do Site Portal da Nota Fiscal Eletrônica (4)









