Busca Binária - Não recursivo
Publicado por Fabio Curtis Volpe 29/04/2005
[ Hits: 11.699 ]
Busca não recursivo
/***************************************************************************
Fábio Curtis Volpe
curtis.volpe@gmail.com
BUSCA BINÁRIA
***************************************************************************/
#ifdef HAVE_CONFIG_H
#include <config.h>
#endif
#include <stdio.h>
#include <stdlib.h>
#define MAX 10
int v[MAX];
int main()
{
int i, ele;
for(i=0; i<MAX; i++)
{
v[i]=rand()/10000000;
}
/* ordenando o vetor - quicksort */
qs(v, 0, MAX-1);
printf("Elementos do vetor\n");
for(i=0;i<MAX;i++)
printf("%d\n", v[i]);
printf("\nBusca Binária\n");
printf("Digite um elemento:");
scanf("%d", ele);
buscaBinaria(v, ele, 0, MAX);
}
void qs(int *v, int left, int right)
{
int i, j;
int x, y;
i=left; j=right;
x=v[(left+right)/2];
do {
while(v[i]<x && i<right) i++;
while(x<v[j] && j>left) j--;
if(i<=j) {
y=v[i];
v[i]=v[j];
v[j]=y;
i++; j--;
}
}while(i<=j);
if(left<j) qs(v, left, j);
if(i<right) qs(v, i, right);
}
void buscaBinaria(int *v, int *ele, int inicio, int fim)
{
int meio, i, f, elemento=0;
elemento=*ele;
while(inicio<=fim){
meio=(inicio+fim)/2;
if(elemento<v[meio])
{
meio=meio-1;
fim=meio;
}
else//(elemento>v[meio]);
inicio=meio+1;
}
if(elemento!=v[meio])
printf("\nNão existe o elemento %d\n\a\a", elemento);
else
printf("\nExiste o elemento %d\n\a\a", v[meio]);
}
[C] Decompositor de números em fatores primos
Nenhum comentário foi encontrado.
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
Novos apps de produtividade, avanços em IA e distros em ebulição agitam o universo 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
Programa fora de escala na tela do pc (10)
Fedora KDE plasma 42 X Módulo de segurança BB (Warsaw-2) (1)
O programa assinador digital (1)









