Función en recursividad

Iniciado por sora_ori, 7 Abril 2014, 21:46 PM

0 Miembros y 1 Visitante están viendo este tema.

Eternal Idol

Cita de: NikNitro! en  8 Abril 2014, 00:44 AM
Y qué diferencia hay? Además, lo del else era una forma diferente de hacerlo... Bueno no discuto más. Sora, si quieres ejercicios resueltos, tengo mi blog en la firma ;)

Salud

Que hagan algo mas que copiar y pegar, es lo minimo, sino estamos haciendo tareas ajenas directamente.
La economía nunca ha sido libre: o la controla el Estado en beneficio del Pueblo o lo hacen los grandes consorcios en perjuicio de éste.
Juan Domingo Perón

sora_ori

Gracias por la ayuda "NikNitro!", te lo agradezco!

El código lo llevo así:

#include <stdio.h>
#include <stdlib.h>

#define FALSE 0
#define TRUE 1
int numLlamadas = 0; //CAMBIADO

/* Declaracion de las funciones */
unsigned int f2x3 (int);

/* Menu principal */
int main(void){
    unsigned int n; // Variable "n" donde se guarda el numero y que utilizará la funcion

    printf("Escribe un numero: ");
    fflush(stdin);
    scanf("%d", &n); // guardamos el numero introducido

    printf("\nTotal de llamadas: %d \n", numLlamadas); // Mostramos el total de llamadas de la funcion //CAMBIADO

    getch();       
    return 0;
} // Fin main

/* Funcion */
unsigned int f2x3 (int n) {
    int i = 0;      //El siguiente número que usaremos  //CAMBIADO
    printf("%i ", n); // Listamos los numeros que va llamando la funcion

    if (n == 1) return 1; // Primer caso, si el valor es igual a 1 entonces retornará 1
    else { //CAMBIADO
      (n % 2 == 0) && (n % 3 == 0) i=n+5; // Caso II //CAMBIADO
      (n % 2 == 0) && (n % 3 != 0) i=n/2; // Caso III //CAMBIADO
      (n % 2 != 0) && (n % 3 == 0) i=n+2; // Caso IV //CAMBIADO
      (n % 2 != 0) && (n % 3 != 0) i=n-1; // Caso V //CAMBIADO
    } //CAMBIADO
   
    numLlamadas++; //CAMBIADO
    return f2x3(i); //CAMBIADO
} // Fin de la funcion




El error que me da es el siguiente:

In function `f2x3':
syntax error before "i"

noele1995

Bueno el error te da por este codigo (n % 2 == 0) && (n % 3 == 0) i=n+5; // Caso II //CAMBIADO
(n % 2 == 0) && (n % 3 != 0) i=n/2; // Caso III //CAMBIADO
(n % 2 != 0) && (n % 3 == 0) i=n+2; // Caso IV //CAMBIADO
(n % 2 != 0) && (n % 3 != 0) i=n-1; // Caso V //CAMBIADO


Intentas hacer ifs pero no estas poniendo ningun if... aun asi yo lo sustituiria por ifs anidados y de esta forma evitamos comprobaciones innecesarias.

if (n == 1)
    return 1;
else
{
    if (n % 2 == 0)
        if (n % 3 == 0)
            i=n+5;
        else
            i=n/2;
    else
        if (n % 3 == 0)
            i=n+2;
        else
            i=n-1;
}


Saludos

sora_ori

Lo he podido compilar, pero la versión que me ha hecho "NikNitro" no me hace nada!  :-X



¿Es correcto lo que me hiciste? Con mi anterior versión me listaba los números.


Saludos

leosansan


Hecho de prisa y corriendo, creo que esta es la salida correcta:

Citar
Escribe un numero: 18
18 23 22 11 10 5 4 2 1
Total de llamadas: 9


Process returned 0 (0x0)

Unos pequeños ajustes menores en la declaración de la función:

Código (cpp) [Seleccionar]
void  f2x3 (int n,int i) ;


Lo de la variable i es para ir guardando las llamadas a la función. Y en main:

Código (cpp) [Seleccionar]
scanf("%d", &n);
    f2x3(n,i);


Y para terminar en la función, a lo bruto:

Código (cpp) [Seleccionar]
void  f2x3 (int n,int i) {
    if (n == 1){
      printf ("%d ",n);
      printf("\nTotal de llamadas: %d \n", ++i);
    }
    else
    {
        if (n % 2 == 0 && n % 3 == 0){
          printf ("%d ",n);
          f2x3 (n+5,i+1);
        }
        else if (n % 2 == 0 &&  n % 3 != 0){
              printf ("%d ",n);
              f2x3 (n/2,i+1);
            }
        else if (n % 3 == 0 && n % 2 != 0){
              printf ("%d ",n);
              f2x3 (n+2,i+1);
            }
        else if (n % 2 != 0 &&  n % 3 != 0){
              printf ("%d ",n);
              f2x3 (n-1,i+1);
            }
    }
}


¡¡¡¡ Saluditos! ..... !!!!



noele1995

No estas llamando a la funcion en el main... normal que no te funcione.

Porcierto numllamadas++ tiene que estar antes de los ifs y no justo antes del ultimo return porque sino hay una llamada que no se contaria....

A mi si que me funciona

Saludos