¿Me echáis un cable?

Iniciado por kayron8, 26 Marzo 2013, 00:11 AM

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

kayron8

Cita de: durasno en 26 Marzo 2013, 02:15 AM
Como consejo personal para kayron8 por ahora, no te acostumbres a usar variables globales ya que recien te estas iniciando, y como muchos usan este recurso para facilitarse los ejercicios al final terminan complicandose... Igual esto es cuestion de cada uno, mientras entiendan lo que hacen esta bien


Saludos

Lo tendré en cuenta ;)
¡Salu2 a to2!

avesudra

Cita de: durasno en 26 Marzo 2013, 02:15 AM
Como consejo personal para kayron8 por ahora, no te acostumbres a usar variables globales ya que recien te estas iniciando, y como muchos usan este recurso para facilitarse los ejercicios al final terminan complicandose... Igual esto es cuestion de cada uno, mientras entiendan lo que hacen esta bien


Saludos
Llevas muchísima razón, lo mejor en ese código hubiese sido esto(utilizando variables locales en las funciones):
#include <stdio.h>
#include <stdlib.h>

void metrosAPies();
void piesAMetros();

int main ()
{

   int eleccion = 0;
   printf("CONVERSOR METROS-PIES\n");
   printf("---------------------------\n");
   printf("1. Metros a pies.\n");
   printf("2. Pies a metros.\n");
   printf("\nSelecciona numero: ");
   scanf("%d",&eleccion);

   if(eleccion == 1)
   {
       metrosAPies();
   }
   else if(eleccion == 2)
   {
       piesAMetros();
   }
   else
   {
       printf("\nNo ha seleccionado una opcion correcta.");
   }
   getchar();
   return 0;
}

void metrosAPies()
{
   float metros    = 0;
   float pies      = 0;
   printf("\nIntroduzca los metros a convertir: ");
   scanf("%f",&metros);
   pies = metros / 0.3048;
   printf ("\n%.2f pies son: %.2f metres\n",pies,metros);
}
void piesAMetros()
{
   float metros    = 0;
   float pies      = 0;
   printf("\nIntroduzca los pies a convertir: ");
   scanf("%f",&pies);
   metros = pies * 0.3048;
   printf("\n%.2f metros son: %.2f pies\n",metros,pies);
}

Regístrate en

kayron8

Cita de: avesudra en 26 Marzo 2013, 12:52 PM
Llevas muchísima razón, lo mejor en ese código hubiese sido esto(utilizando variables locales en las funciones):
#include <stdio.h>
#include <stdlib.h>

void metrosAPies();
void piesAMetros();

int main ()
{

   int eleccion = 0;
   printf("CONVERSOR METROS-PIES\n");
   printf("---------------------------\n");
   printf("1. Metros a pies.\n");
   printf("2. Pies a metros.\n");
   printf("\nSelecciona numero: ");
   scanf("%d",&eleccion);

   if(eleccion == 1)
   {
       metrosAPies();
   }
   else if(eleccion == 2)
   {
       piesAMetros();
   }
   else
   {
       printf("\nNo ha seleccionado una opcion correcta.");
   }
   getchar();
   return 0;
}

void metrosAPies()
{
   float metros    = 0;
   float pies      = 0;
   printf("\nIntroduzca los metros a convertir: ");
   scanf("%f",&metros);
   pies = metros / 0.3048;
   printf ("\n%.2f pies son: %.2f metres\n",pies,metros);
}
void piesAMetros()
{
   float metros    = 0;
   float pies      = 0;
   printf("\nIntroduzca los pies a convertir: ");
   scanf("%f",&pies);
   metros = pies * 0.3048;
   printf("\n%.2f metros son: %.2f pies\n",metros,pies);
}



Hola, muchas gracias por la ayuda, sois mejores que mi profe de programación jejeje

Me quedo con esta segunda versión ya que el profe prefiere este modo que no el primero que se planteó.

Saludos :D
¡Salu2 a to2!

85

que raro porque los profesores son los que siempre dicen que no usés variables globales.
Me cerraron el Windows Live Spaces, entonces me creé un WordPress XD
http://etkboyscout.wordpress.com/

kayron8

Por eso me quedo con la segunda versión del ejercicio xD
¡Salu2 a to2!

kayron8

#15
¡Hola, buenas noches de nuevo!

Tengo un nuevo ejercicio que hacer, que aparentemente me funciona correctamente pero no sé si está bien escrito su código.

El enunciado del ejercicio, es el síguete:

"Escribe el código en C de la función que imprima por pantalla tantos asteriscos como indique el número que reciba como argumento."

El código que llevo por ahora es el siguiente:

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

int asteriscos(int i);

int main(){  
 int i=0,num=0;  
 
   printf("Itroduce un numero: \n");  
   scanf("%d",&num);  
 
   for(i=0;i<num;i++)  
       printf("* ");  
   getch();  
   
system("pause");
return 0;  
}

int asteriscos(int i){
return "* ";
}


Muchas gracias por vuestra ayuda "profes" :P
¡Salu2 a to2!

avesudra

#16
Pregunta nueva, tema nuevo. De todas maneras lo que tiene que imprimir por pantalla los asteriscos es la función, y ni llamas a la función ni la función hace lo que dice el enunciado. En todo caso sería llamando a la función y pasándole la cantidad de asteriscos a imprimir por pantalla:
#include <stdio.h>
#include <stdlib.h>

void printAsterisks(unsigned int numOfAsterisks);

int main()
{
   unsigned int num = 0;

   printf("Introduce un numero: \n");
   scanf("%u",&num);

   printAsterisks(num);

   system("pause");
   return 0;
}

void printAsterisks(unsigned int numOfAsterisks)
{
   while(numOfAsterisks)
   {
    printf("* ");
    --numOfAsterisks;
   }
}

Creo que deberías darle un repaso al uso de las funciones, porque no sabes usarlas o da la impresión de eso. A una función tu le pasas unos parámetros y o hace una cosa y no devuelve nada como en este caso. O evalúa un problema y devuelve una solución. ¡Pero tienes que llamarla , si no no hace nada!
Regístrate en

kayron8

La verdad es que sí, me hace falta un buen repaso. Programo en varios lenguajes y me lio bastante :(

La condición while, la remplace con tú permiso, por mi for antiguo, este cambio lo hice porque con tu código me imprime asteriscos de forma infinita.

Luego una pequeña tontería, en la línea 11, cuando escribes scanf("%ud",&num);
¿no sería scanf("%d",&num);?

Muchas gracias de nuevo
¡Salu2 a to2!

avesudra

#18
Cita de: kayron8 en 27 Marzo 2013, 00:35 AM
Luego una pequeña tontería, en la línea 11, cuando escribes scanf("%ud",&num);
¿no sería scanf("%d",&num);?
Es que he cambiado el tipo a unsigned int ya que no tiene sentido imprimir -4 asteriscos  :xD de todas maneras me he equivocado sería:
scanf("%u",&num);
No sé porque te genera un bucle infinito, a mi no me lo genera ni en Windows ni en Linux(Ubuntu) sobre el compilador GCC sobre Linux y MinGW sobre Windows y el IDE Codeblocks.
Regístrate en