Cita:
Iniciado por vangodp Bueno... Anoche estube contestando un post por internet y se trataba de funciones recursivas
No tengo mucha practica con eso pero logre hacer un ejercicio que para mi ha sido algo duro jaja, pero logre hacer lo que postare mas abajo.
El usuario habia pedido que dado un numero como 3183 de 4 digitos.
comaparase cada digito con el ultimo y si fuera mayor o igual, se multiplicara por el seguiente.
El numero 3183 seria n = 3*8*3 que daria 72. El 1 se desecha ya que no es mayor que el ultimo.
Mi pregunta es....
¿Hay alguna forma mas facil de hacer que la que hice yo? Lo digo por que con recursivas no tengo NPI XDDD
......................
¿Y ademas cual es la ventaja de usar eso?
Suerte chicos
Ventajas respecto a un ciclo más bien pocas ya que hay que estar invocando a la función una y otra vez, cosa que en un ciclo simple te lo ahorras. Como ejercicio no está mal.
Te dejo en el código un par de cout para que veas como trabaja. Si se los pones en tu código veras que está trabajando de más y es por la falta de los return.
Código C++:
Ver original#include <iostream>
using namespace std;
int f ( int n ) {
static int a = 1 , u = n % 10 ;
if ( n > 0 ) {
if ( n % 10 >= u )
a = a * ( n % 10 ) , cout << "a = " << a << endl;
else
cout << "Desechando la ultima posicion de n: " << n % 10 << ". Es menor que static u: " << u << endl
, cout << "n ahora contiene " << n / 10 << ", y se envia a f() para seguir multiplicando..." << endl;
return f ( n / 10 );
}
cout << "Retornando: " << a << endl;
return a;
}
int main() {
int n = 3183;
cout << f ( n ) << endl;
cin.ignore();
return 0;
}
Un fuerte saludo
vangodp ¡¡¡Saluditos!!!