Ver Mensaje Individual
  #4 (permalink)  
Antiguo 11/09/2007, 08:04
Avatar de _Lucifer_
_Lucifer_
 
Fecha de Ingreso: junio-2006
Mensajes: 1.662
Antigüedad: 18 años, 7 meses
Puntos: 28
Re: Rcursividad en ANSI C

Cita:
Iniciado por moyka Ver Mensaje
Hola,
hombre en ese caso no haría falta llegar hasta cero, al llegar a 1 ya puedes parar la recursión.

Otro buen ejemplo puede ser el de realizar una potencia de un número de forma recursiva, lo más importante en la recursividad es encontrar el caso base, una vez encontrado (como en el ejemplo anterior del factorial), todo va ya sobre ruedas.


En el ejemplo de la potencia de un número, el caso base es cuando el exponente es 1, todo número elevado a 1 es igual a dicho número, así que en esta función, decrementaremos el exponente en una unidad hasta llegar a uno.

Lo único que resta para tener la función completa es ver el número con el que operar en la llamada recursiva, es decir, en este caso multiplicaremos cada llamada recursiva por el número a elevar.

Sería así:

Código:
int elevar(int base,int exponente){
    if(exponente == 1)
       return 1;
    return (elevar(base,exponente-1)*base);
}
Espero haberte ayudado un poco, si necesitas más ejemplos mándame un privado.
Un saludo.
Una correccíon:
Código:
int elevar(int base,int exponente){
    if(exponente == 0)
       return 1;
    return (elevar(base,exponente-1)*base);
}
Si quieres llegarlo hasta 1 sería:
Código:
int elevar(int base,int exponente){
    if(exponente == 1)
       return base;
    return (elevar(base,exponente-1)*base);
}
Cualquier número elevado a la 1 es el mismo número y cualquier número elevado a la 0 es 1.

Saludos
__________________
Si crees que no tiene sentido, etonces probablemente lo tenga... :arriba: