Introdução a Recursão
Publicado por Rafael 09/03/2007
[ Hits: 6.459 ]
Homepage: nenhum
Um exemplo simples de recursão. Espero que sirva de base para ajudar a compreeender o uso do algoritmo de quicksort e busca binária.
Neste exemplo eu preencho um vetor com 11 posições(0 à 11) que armazena ponteiros para pontos, sempre visitando a posição média do vetor e em seguida e média da média e assim por diante.
Enquanto isso, vou armazenando os pontos médios dos pontos armazenados nas extremidades.
#include <iostream.h>
struct ponto{
    float x;
    float y;
    };
void X(ponto** p, ponto* p1, ponto* p2, int i, int f){
int novapos;
if ((i+f) % 2 == 1){
    novapos = ((i+f)+1)/2;
} else {
    novapos = (i+f)/2;
}
if (p[novapos]==NULL)   {
    ponto *np = (ponto*) malloc(sizeof(ponto*));
    (*np).x = ((*p1).x + (*p2).x)/2;
    (*np).y = ((*p1).y + (*p2).y)/2;
    
    p[novapos] = np;
    X(p, p1, np, i, novapos);
    X(p, np, p2, novapos, f);
    }
}
int main()
{
    ponto* pini = (ponto*) malloc(sizeof(ponto*));
    ponto* pfim = (ponto*) malloc(sizeof(ponto*));
    (*pini).x = 0;
    (*pini).y = 0;
    (*pfim).x = 10;
    (*pfim).y = 10;
    ponto **p = (ponto**) malloc(11*sizeof(ponto*));
    p[0] = pini;
    p[10] = pfim;   
    X(p, pini, pfim, 0, 10);
// Imprime os resultados no Console
    for (int i=0;i<=10;i++){      
       cout<<"-------"<<endl;
       cout<<i<<endl;
   cout<<"x:"<<(*p[i]).x<<endl;
       cout<<"y:"<<(*p[i]).y<<endl;
       cout<<"-------"<<endl;
    }   
    return 0;
}
Desenhando uma curva Dragão ou o Fractal Jurassic Park
Métodos de Ordenação - Quick Sort
Converter Decimal para Binário em C
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
Atualizando o Fedora 42 para 43
Como saber se o seu e-mail já teve a senha vazada?
Como descobrir se a sua senha já foi vazada na internet?
Instalação dualboot Windows 11 e Debian 13 (0)
Programa fora de escala na tela do pc (33)
Eu queria adicionar a incon do wifi e deixa transparente no fluxbox no... (0)









