Torre Hanoi mostrar numero de movimientos en C

Iniciado por EmmanuelTR9, 1 Octubre 2019, 02:43 AM

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

EmmanuelTR9

No puedo mostrar el numero de movimientos que realiza solo los muestra, alguien me podria orientar, agregue int factorial para que pueda ya que me explicaron que se tenia que agregar ello pero no puedo.

[code=c]#include <stdio.h>

#include <stdio.h>

int factorial(int x){
   int rta;
   if(x==0)
       rta=1;
       else
       rta=x*factorial(x-1);
       return rta;
}

void hanoi(int n,int inic,int tmp,int final){
 
}

}
[/code]


engel lex

#1
CitarNo puedo mostrar el numero de movimientos que realiza solo los muestra

no entiendo, los muestra o no los muestra

asumiendo que no los muestra es por

printf("\n", factorial);

le pasas como parametro factorial, pero no lo incluyes en el formato

recuerda que debes pasar el tipo a motrar en el formato

printf("\nMover el disco %d de la base %c a la base %c",n,inic,tmp);

como lo haces allí




por otro lado, las malas practicas

1- main debe ser de tipo int siempre
2- no hagas if sin corchetes, no agrega nada positivo al codigo, solo dificulta la lectura y aumento la posibilidad de incluir un bug accidental
3- las funciones recursivas no son la mejor solucion a los problemas, mal implementada puede sobrecargar la pila de instrucciones y causar fallos en el programa, un ciclo haría este trabajo perfectamente y haría el codigo mas legible
El problema con la sociedad actualmente radica en que todos creen que tienen el derecho de tener una opinión, y que esa opinión sea validada por todos, cuando lo correcto es que todos tengan derecho a una opinión, siempre y cuando esa opinión pueda ser ignorada, cuestionada, e incluso ser sujeta a burla, particularmente cuando no tiene sentido alguno.

EmmanuelTR9

Cita de: engel lex en  1 Octubre 2019, 02:57 AM
no entiendo, los muestra o no los muestra

asumiendo que no los muestra es por

printf("\n", factorial);

le pasas como parametro factorial, pero no lo incluyes en el formato

recuerda que debes pasar el tipo a motrar en el formato

printf("\nMover el disco %d de la base %c a la base %c",n,inic,tmp);

como lo haces allí




por otro lado, las malas practicas

1- main debe ser de tipo int siempre
2- no hagas if sin corchetes, no agrega nada positivo al codigo, solo dificulta la lectura y aumento la posibilidad de incluir un bug accidental
3- las funciones recursivas no son la mejor solucion a los problemas, mal implementada puede sobrecargar la pila de instrucciones y causar fallos en el programa, un ciclo haría este trabajo perfectamente y haría el codigo mas legible

Gracias por responder, la verdad no se como implementarlo solo el maestro nos indico que teniamos que hacer ello para que pudieramos contar pero de ahi no explico mas me podrias orientar ?

engel lex

Citarprintf("\nMover el disco %d de la base %c a la base %c",n,inic,tmp);

el formato incluye % seguido de una letra para indicar el tipo de dato, esto será remplazado por los valores pasados a continuacion en orden, fijate alli %d corresponde a la variable n que es un "digito" (para hacerlo mas facil de recordar), luego %c corresponde a inic y tmp que son "caracteres"

en tal caso necesitas incluir el %d para imprimir el resultado
El problema con la sociedad actualmente radica en que todos creen que tienen el derecho de tener una opinión, y que esa opinión sea validada por todos, cuando lo correcto es que todos tengan derecho a una opinión, siempre y cuando esa opinión pueda ser ignorada, cuestionada, e incluso ser sujeta a burla, particularmente cuando no tiene sentido alguno.

EmmanuelTR9

Cita de: engel lex en  1 Octubre 2019, 03:08 AM
el formato incluye % seguido de una letra para indicar el tipo de dato, esto será remplazado por los valores pasados a continuacion en orden, fijate alli %d corresponde a la variable n que es un "digito" (para hacerlo mas facil de recordar), luego %c corresponde a inic y tmp que son "caracteres"

en tal caso necesitas incluir el %d para imprimir el resultado

Los movimientos si me los imprime correctamente, solo que no puedo mandar a llamar las repeticiones al ingresar numero

engel lex

Citaren tal caso necesitas incluir el %d para imprimir el resultado

cambia la linea 30 por

Código (cpp) [Seleccionar]
printf("\n esto-> %d <-", factorial);
El problema con la sociedad actualmente radica en que todos creen que tienen el derecho de tener una opinión, y que esa opinión sea validada por todos, cuando lo correcto es que todos tengan derecho a una opinión, siempre y cuando esa opinión pueda ser ignorada, cuestionada, e incluso ser sujeta a burla, particularmente cuando no tiene sentido alguno.

EmmanuelTR9

#6
Cita de: engel lex en  1 Octubre 2019, 03:51 AM
cambia la linea 30 por

Código (cpp) [Seleccionar]
printf("\n esto-> %d <-", factorial);


Mira ya lo puse pero me da otra cantidad estatica


engel lex

disculpa, mea culpa, se me pasó por alto que era un funcion, no una variable... debes pasarle el valor al factorial para que lo calcule

Código (cpp) [Seleccionar]
printf("\n esto-> %d <-", factorial(n));
El problema con la sociedad actualmente radica en que todos creen que tienen el derecho de tener una opinión, y que esa opinión sea validada por todos, cuando lo correcto es que todos tengan derecho a una opinión, siempre y cuando esa opinión pueda ser ignorada, cuestionada, e incluso ser sujeta a burla, particularmente cuando no tiene sentido alguno.

EmmanuelTR9

Cita de: engel lex en  1 Octubre 2019, 04:07 AM
disculpa, mea culpa, se me pasó por alto que era un funcion, no una variable... debes pasarle el valor al factorial para que lo calcule

Código (cpp) [Seleccionar]
printf("\n esto-> %d <-", factorial(n));

Disculpa pero no entiendo como pasarle el valor al factorial

EmmanuelTR9

Cita de: engel lex en  1 Octubre 2019, 04:07 AM
disculpa, mea culpa, se me pasó por alto que era un funcion, no una variable... debes pasarle el valor al factorial para que lo calcule

Código (cpp) [Seleccionar]
printf("\n esto-> %d <-", factorial(n));

ya lo hice pero al momento cuando pongo 3 me dice 6 pero son 7 pasos no estara mal mi factorial ?