Menú

Mostrar Mensajes

Esta sección te permite ver todos los mensajes escritos por este usuario. Ten en cuenta que sólo puedes ver los mensajes escritos en zonas a las que tienes acceso en este momento.

Mostrar Mensajes Menú

Mensajes - CCross

#31
leosansan gracia por darte el tiempo de aclararme la duda que tenia, esto de la
recursividad esta complicadita. Y efectivamente una solucion recursiva generalmente
es menos eficiente por el consumo de mayor de recursos que la iterativa. Sin embargo en
muchas situacion nos puede facilitar las cosas.

Saludos..  ;D
#32
Hola prueba de esta forma, te imprimira cada direccion de las variables apuntada
por el vector de punteros creo que es eso lo que buscas.

Código (cpp) [Seleccionar]
#include <iostream>

using namespace std;

void muestraD_arreglo(int* pArreglo[])
{
    cout << (int)pArreglo[0] << endl; // Si quieres los valores seria *pArreglo[0]
    cout << (int)pArreglo[1] << endl;
    cout << (int)pArreglo[2] << endl;
    cout << (int)pArreglo[3] << endl;
}

int main()
{
   int b = 15 , c = 30 , d = 29 , e = 76 ;
   int *a[4];

   a[0] = &b;
   a[1] = &c;
   a[2] = &d;
   a[3] = &e;

   muestraD_arreglo(a);

   cin.get();
   return 0;
}


Saludos   ;D
#33
Hola leosansan excelete codigo lo de itoa no lo sabia muy bueno pero aun
no logro enterder del todo este codigo:

Código (cpp) [Seleccionar]
return divide > 0 ? binario(divide) * 10 + resto : resto;

Especificamente en la parte de la multiplicacion por diez y luego la suma me
gustaria saber que valor devuelve la funcion de cada llama a ella yo supongo
que seria cero.

Saludos  :rolleyes:
#34
Muchas gracias cypascal por la aclaracion, he buscado por internet
y he encontrado una funcion que hace esto de una menera mas simple:

Código (cpp) [Seleccionar]
void binario(int n)
{
   if (n!=0)
   {
       binario(n/2);
       printf("%i",n%2);
    }
}


Esta divide el numero entre dos hasta que quede 0 y apunta a los residuos
del ultimo al primero. Los restos generados en cada division forman el
numero binario el primer resto es el bit menos significativo (LSB) y el
último resto es el bit mas significativo (MSB) del numero binario.

Código (bash) [Seleccionar]
10/2 = 05 con residuo 0 <--- LSB
05/2 = 02 con residuo 1
02/2 = 01 con residuo 0
01/2 = 00 con residuo 1 <--- MSB


Código (bash) [Seleccionar]
Eso se imprimiria de esta forma 1010

En este caso segun entiendo la funcion printf imprime inversamente
los residuos resultante de la division, aprovecha esa propiedad de
imprimir el bit mas significativo primero y el LBS al ultimo siendo el
primero en originarse, podria alguien explicarme como esto es posible..

cypascal lo que entendi fue que al multiplicarlo por 10 consiste
una forma de ir ordenado los residuos de forma inversa seria algo asi no

Un saludo

#35
Cita de: amchacon en 16 Mayo 2013, 10:15 AM
Creo que no es num sino dec.

Si efectivamente habia cambia los parametros para que sea mas congruentes
me olvide hacer los cambios dentro jeje:.

Código (cpp) [Seleccionar]
int binario(int dec)
{
   int resto = dec % 2;
   int divide = dec / 2;

   return divide > 0 ? binario(divide) * 10 + resto : resto;
}


Y hiendo al tema que opinas estoy en lo corecto seria asi como funciona  o no¿?

Saludos
#36
Hey!! buenas a todos los apasionados de esto de la programacion, me acabo de inscribir
en el foro. Yo soy unas de esas personas que cuando encuentra un codigo que no  
entiende, trata estudiar como funciona cada expresion, funcion etc;

En fin la cuestion es que me he topado con un codigo que me cuesta un poco comprenderlo
especificamente se trata de una funcion recursiva que lo que hace es convertir un un
numero decimal a binario miren esta es la funcion:

Código (cpp) [Seleccionar]
int binario(int dec)
{
   int resto = num % 2;
   int divide = num / 2;

   return divide > 0 ? binario(divide) * 10 + resto : resto;
}


Lo que llegue a entender es que si dvide es mayor que cero, se ejecuta la funcion
que luego es multiplicada por diez y se le suma uno. Por decirlo si yo le paso un siete
a la funcion, en un primer momento resto valdria 1 y divide seria 3 como ven
divide es mayor que cero, por lo que la funcion se ejecuta.

Lo mas logico es que la funcion binario(divide) retornara un cero que es
multiplicada por 10 que da 0 y luego se le suma 1 y asi sucesivamente en caso de que
divide no sea mayor que 0 se ejecuta el bloque correspondiente a false que le agrega
cero

Que me corrijan si esto no es asi saludos a todos  :rolleyes: