Autor
|
Tema: Ayuda! Soy nuevo en programacion "C" Necesicito que me ayuden con FUNCIONES (Leído 5,293 veces)
|
smdiegoarmando
Desconectado
Mensajes: 12
|
La verdad hice el esfuerzo de terminar el programa, pase toda la noche intentando que corra y no lo logre lo ideas seria que cada opcion llevara funciones pero se me hizo dificil Uso Dev-C ... AYUDAAAA
#include<stdio.h> #include<stdlib.h> #include<time.h> #include<conio.h> int cubo ( int n ) { return n*n*n; } int multiplo ( int x, int y) { return x%y; } int main(){ int i, temp,n1,n2; int _cont; int opc,numero,resultado; srand(time(NULL)); for(i=0 ; i<5 ; i++){
printf(" \n Menu "); printf(" \n 1...Generar y mostrar 5 números aleatorios del 1 al 10 "); printf(" \n 2...Cubo de un número entero "); printf(" \n 3...Determinar si un numero es múltiplo de otro "); printf(" \n 4...Mostrar los números pares entre 1 y 40 "); printf(" \n 5...Salir "); printf(" \n ESCOJA UNA OPCION "); scanf("%d",opc); switch (opc)
{ case 1: puts("Generar y mostrar 5 números aleatorios del 1 al 10"); printf("Numero aleatorio %d es : %d\n",i+1, rand()%10 ); getch(); main(); break; case 2: puts("Cubo de un número entero"); printf(" \n Ingrese un numero"); scanf("%d",&numero); resultado = cubo(numero); printf("El cuadrado del numero es %d", resultado); getch(); main(); break; case 3: puts("Determinar si un numero es múltiplo de otro"); printf(" \n Ingrese un numero"); scanf("%d",&n1); printf(" \n Ingrese otro numero"); scanf("%d",&n2); resultado=multiplo(n1,n2); if (n1%n2==0) { printf(" \n Los numeros son multiplos entre si"); } else { printf(" \n Los numeros no son multiplos entre si"); } getch(); main(); break; case 4: puts("Mostrar los números pares entre 1 y 40"); while(_cont<=40){ if(_cont%2==0){ printf("%d, ",_cont); } _cont++; } getch(); main(); break; case 5:puts("salir"); printf("Fin del programa"); getch(); break; default: printf(" opcion invalalida"); } getch(); } system("pause"); }
|
|
« Última modificación: 27 Enero 2013, 17:07 pm por smdiegoarmando »
|
En línea
|
|
|
|
amchacon
Desconectado
Mensajes: 1.211
|
case 1: puts("Generar y mostrar 5 números aleatorios del 1 al 10"); printf("Numero aleatorio %d es : %d\n",i+1, rand()%10 ); getch(); main(); break;
WTF? ¿Porque haces una llamada al main?. Eso es super inestable, cada vez que llames a una función se iran creando llamadas proguesivamente gastando memoria y tiempo de ejecución.... Cuando te quedes sin pila el programa te crasheara estrepidosamente. Si lo que quieres esque el programa se repita continuamente ponlo dentro de un while: #include<stdio.h> #include<stdlib.h> #include<time.h> #include<conio.h> int cubo ( int n ) { return n*n*n; } int multiplo ( int x, int y) { return x%y; } int main() { int i, temp,n1,n2; int _cont; int opc,numero,resultado; srand(time(NULL)); while (true) { printf(" \n Menu "); printf(" \n 1...Generar y mostrar 5 números aleatorios del 1 al 10 "); printf(" \n 2...Cubo de un número entero "); printf(" \n 3...Determinar si un numero es múltiplo de otro "); printf(" \n 4...Mostrar los números pares entre 1 y 40 "); printf(" \n 5...Salir "); printf(" \n ESCOJA UNA OPCION "); scanf("%d",opc); switch (opc) { case 1: puts("Generar y mostrar 5 números aleatorios del 1 al 10"); printf("Numero aleatorio %d es : %d\n",i+1, rand()%10 ); getch(); break; case 2: puts("Cubo de un número entero"); printf(" \n Ingrese un numero"); scanf("%d",&numero); resultado = cubo(numero); printf("El cuadrado del numero es %d", resultado); getch(); break; case 3: puts("Determinar si un numero es múltiplo de otro"); printf(" \n Ingrese un numero"); scanf("%d",&n1); printf(" \n Ingrese otro numero"); scanf("%d",&n2); resultado=multiplo(n1,n2); if (n1%n2==0) { printf(" \n Los numeros son multiplos entre si"); } else { printf(" \n Los numeros no son multiplos entre si"); } getch(); break; case 4: puts("Mostrar los números pares entre 1 y 40"); while(_cont<=40) { if(_cont%2==0) { printf("%d, ",_cont); } _cont++; } getch(); break; case 5: puts("salir"); printf("Fin del programa"); getch(); break; default: printf(" opcion invalalida"); } getch(); system("CLS"); // Comando para borrar la pantalla } system("pause"); }
También te he quitado el for del principio porque no servía para nada...
|
|
|
En línea
|
|
|
|
avesudra
Desconectado
Mensajes: 724
Intentando ser mejor cada día :)
|
A parte de lo dicho por amchacon te lo he puesto en funciones, pero trabaja un poco más porque es que el código es sucio.Y no te digo nada de la portabilidad...Además te faltaba un ampersand al introducir la opción en ese scanf. En fín: #include<stdio.h> #include<stdlib.h> #include<time.h> #include<conio.h>//Esto sería bueno quitarlo pero bueno //PROTOTIPOS DE FUNCIONES int multiplo ( int x, int y); void aleatorio(); void cubo(); void esMultiplo(); void pares(); void salir(); int main() { int opc; do { printf(" \n 1...Generar y mostrar 5 números aleatorios del 1 al 10 "); printf(" \n 2...Cubo de un número entero "); printf(" \n 3...Determinar si un numero es múltiplo de otro "); printf(" \n 4...Mostrar los números pares entre 1 y 40 "); printf(" \n ESCOJA UNA OPCION "); switch (opc) { case 1: aleatorio(); break; case 2: cubo(); break; case 3: esMultiplo(); break; case 4: pares(); break; case 5: break; default: } if(opc!=5) { printf("Presione una tecla para volver al menu principal . . . "); } } while(opc!=5); return 0; } //DEFINICIÓN DE FUNCIONES int multiplo(int x,int y) { return x%y; } void aleatorio() { puts("Generar y mostrar 5 números aleatorios del 1 al 10"); int i; for(i=0; i!=5; ++i) { printf("Numero aleatorio %d es : %d\n",i +1, rand()%10 ); } } void cubo() { int numero=0; int resultado=0; puts("Cubo de un número entero"); printf(" \n Ingrese un numero"); resultado = numero*numero*numero; printf("El cuadrado del numero es %d", resultado ); } void esMultiplo() { int n1,n2,resultado; puts("Determinar si un numero es múltiplo de otro"); printf(" \n Ingrese un numero"); printf(" \n Ingrese otro numero"); resultado=multiplo(n1,n2); if (n1%n2==0) { printf(" \n Los numeros son multiplos entre si"); } else { printf(" \n Los numeros no son multiplos entre si"); } } void pares() { int _cont; puts("Mostrar los números pares entre 1 y 40"); while(_cont<=40) { if(_cont%2==0) { } _cont++; } }
|
|
« Última modificación: 27 Enero 2013, 17:34 pm por avesudra »
|
En línea
|
Regístrate en 
|
|
|
smdiegoarmando
Desconectado
Mensajes: 12
|
Ciertamente no entiendo porque el programa corre pero al ingresar una de las opciones del 1 al 5 se cierra automaticamente muestra -> NombreDelPrograma.exe dejo de funcionar.
Sera que tego problema con el Dev-C ?
|
|
|
En línea
|
|
|
|
avesudra
Desconectado
Mensajes: 724
Intentando ser mejor cada día :)
|
Pero cual de los códigos, ¿el que tu has puesto, el que ha puesto amchacon o el que he puesto yo? El que tu y amchacon habeis puesto debería dar error en ejecución como dices por esta sentencia, donde falta un ampersand:
Debería estar así:
|
|
« Última modificación: 27 Enero 2013, 17:44 pm por avesudra »
|
En línea
|
Regístrate en 
|
|
|
smdiegoarmando
Desconectado
Mensajes: 12
|
Pero cual de los códigos, ¿el que tu has puesto, el que ha puesto amchacon o el que he puesto yo?
Avesudra utilice tu codigo
|
|
|
En línea
|
|
|
|
avesudra
Desconectado
Mensajes: 724
Intentando ser mejor cada día :)
|
|
|
|
En línea
|
Regístrate en 
|
|
|
dato000
Desconectado
Mensajes: 3.034
|
Si señor, poco más puedo agregar a los gurus de aqui, dev-c++ apesta a millones, CodeBlocks con MinGW es mucho pero millones años luz mejor.
|
|
|
En línea
|
|
|
|
smdiegoarmando
Desconectado
Mensajes: 12
|
Ya instale el Codeblocks y me va de maravilla el programa es genial y todo gracias a ti aunque por una extraña forma la opcion 4...Mostrar los números pares entre 1 y 40 " no me muestra los numeros :/
|
|
|
En línea
|
|
|
|
avesudra
Desconectado
Mensajes: 724
Intentando ser mejor cada día :)
|
No es extraño es un fallo de programación, ha sido error mío al declarar la variable, perdón jeje  . Para arreglarlo, en la función: void pares() { int _cont; puts("Mostrar los números pares entre 1 y 40"); while(_cont<=40) { if(_cont%2==0) { } _cont++; } }
Debes inicializar _cont en 0 pues sino se inicializa con un valor aleatorio.Quedando así: void pares() { int _cont=0; puts("Mostrar los números pares entre 1 y 40"); while(_cont<=40) { if(_cont%2==0) { } _cont++; } }
|
|
|
En línea
|
Regístrate en 
|
|
|
|
Mensajes similares |
|
Asunto |
Iniciado por |
Respuestas |
Vistas |
Último mensaje |
|
|
La Operacion en varios pasos genero errores... AYUDA AQUI"""""
Programación Visual Basic
|
JoseCheO
|
1
|
8,489
|
23 Diciembre 2011, 16:57 pm
por JoseCheO
|
|
|
Ayuda con programacion en c! "Urgente porfavor"
Programación C/C++
|
Superr29
|
3
|
2,528
|
6 Julio 2012, 21:55 pm
por 0xDani
|
|
|
Ayuda con el siguiente MENU "programacion en C"
Programación General
|
smdiegoarmando
|
1
|
2,263
|
7 Febrero 2013, 16:30 pm
por [Case]
|
|
|
AYUDA POR FAVOR!! :( NUEVO EN PROGRAMACION
Programación C/C++
|
RamonVelz
|
1
|
1,927
|
13 Mayo 2014, 05:48 am
por engel lex
|
|
|
Duda funciones programación en C
Ejercicios
|
LUCHADOR97
|
7
|
4,761
|
16 Diciembre 2016, 01:44 am
por engel lex
|
|