|
371
|
Programación / Programación C/C++ / Re: Ayuda! Soy nuevo en programacion "C" Necesicito que me ayuden con FUNCIONES
|
en: 27 Enero 2013, 17:29 pm
|
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++; } }
|
|
|
373
|
Programación / Programación C/C++ / Re: Problema con las excepciones
|
en: 27 Enero 2013, 13:15 pm
|
Olvidalo , no se porque pasa :/ . Por codeblocks no creo que sea. Aviso que no entiendo muy bien el uso de las sentencias try , catch y throw, pero digamos que throw tiene que lanzar algo ¿no? cuando en throw haces: throw Excepcion("No hay ningun fichero abierto",ARCHIVO_NO_ABIERTO); Pero esa función(constructor) solo le da valores a una estructura ya creada pero tú llamas al constructor sin estructura o eso parece no se.Fíjate aquí: http://publib.boulder.ibm.com/infocenter/lnxpcomp/v8v101/index.jsp?topic=%2Fcom.ibm.xlcpp8l.doc%2Flanguage%2Fref%2Fcplr153.htm Me parece a mi que eso habría que ponerlo así: if (!Lectura.is_open()) { Excepcion excepcion; excepcion.Excepcion("No hay ningun fichero abierto",ARCHIVO_NO_ABIERTO); throw excepcion; } Igual la estoy liando no sé. ¡Un saludo!
|
|
|
374
|
Programación / Programación C/C++ / Re: [src]problema con fflush()
|
en: 27 Enero 2013, 12:26 pm
|
Pero ¿para que limpiar el buffer? Es que es innecesario, son ganas de ponerse a limpiar el buffer. Usad las funciones correctas y punto. Ya lo zanjó hace tiempo Eternal Idol: « Respuesta #3 en: 24 Agosto 2009, 20:13 » Zanjado: NO USAR JAMAS. fgets + sscanf #include <stdio.h> int main(int argc, char **argv) { int opcion; do{ char linea[80]; fgets(linea , sizeof(linea ), stdin ); }while(opcion!=0); return 0; }
Las demás formas de hacerlo son parches para corregir. Hola! como ya te dijeron esa "mala lectura" se debe al ENTER(que tambien es un caracter) que queda almacenado en el bufer del teclado, por eso con el segundo getchar no podes ingresar... Otra alternativa para limpiar el bufer seria algo como: while(getchar()!='\n');/* este bucle debe ir despues de cada getchar*/
Saludos PD: fpurge no es estandar por eso no te funciona Durasno en ese caso deberías comprobar también si es EOF así que quedaría así: char c; while(c =getchar() != '\n' && c != EOF ){}
Pero como ya digo son parches. Hacerlo bien no mata a nadie: #include <stdio.h> int main() { char a,b; char buffer[80]; printf("Which character is bigger?\n"); printf("Type a single character:"); fgets(buffer ,sizeof(buffer ),stdin ); printf("Type another character:"); fgets(buffer ,sizeof(buffer ),stdin ); if(a > b) { printf("'%c' is greater than '%c'!\n",a ,b ); } else if(b > a) { printf("'%c' is greater than '%c'!\n",b ,a ); } else { printf("Next time don't press the same character"); } return(0); }
¡Un saludo!
|
|
|
375
|
Programación / Programación C/C++ / Re: [src]problema con fflush()
|
en: 27 Enero 2013, 00:21 am
|
Esto ocurre porque un salto de línea queda cojo en el buffer de entrada, depurando tu programa se ve esto en el buffer stdin(que en ese momento termina apuntando al primer 0A): 77A07EB1 00 00 00 00 00 00 00 00 ........ 77A07EB9 00 00 00 00 00 00 00 61 .......a 77A07EC1 0A 0A 00 00 00 00 00 00 ........ 77A07EC9 00 00 00 00 00 00 00 00 ........ 77A07ED1 00 00 00 00 00 00 00 00 ........ 77A07ED9 00 00 00 00 00 00 00 00 ........
Si te das cuenta los 0A son saltos de línea y al hacer input con scanf se escriben dos por alguna razón que desconozco , entonces al llamar otra vez a getchar y intentar escribir en la siguiente posición del buffer al haber un fin de línea pues es como si ya hubiese escaneado todo el buffer y pasa de largo. El buffer se vería así: 77A07EC2 0A 00 00 00 00 00 00 00 ........ 77A07ECA 00 00 00 00 00 00 00 00 ........ 77A07ED2 00 00 00 00 00 00 00 00 ........ 77A07EDA 00 00 00 00 00 00 00 00 ........ 77A07EE2 00 00 00 00 00 00 00 00 ........ 77A07EEA 00 00 00 00 00 00 00 00 ........ 77A07EF2 00 00 00 00 00 00 00 00 ........ 77A07EFA 00 00 00 00 00 00 00 00 ........ 77A07F02 00 00 00 00 00 00 00 00 ........
Y al hacer el siguiente getchar pues ya no habría problema porque apuntaría para escribir a la siguiente posición que es una zona vacía. Para evitar todo esto como ya dijo el moderador Eternal Idol hace mucho tiempo se usa fgets + sscanf. Ya que fgets lee desde un stream , n carácteres ( que le pasas como argumento) menos uno , entonces no lee el fin de línea. Un ejemplo de uso: #include <stdio.h> int main(int argc, char *argv[]) { char cadena[100]; char buffer[100]; return 0; }
|
|
|
377
|
Foros Generales / Noticias / Re: Los programadores y sus genes de murciélago
|
en: 26 Enero 2013, 19:13 pm
|
Tenes un bug en un programa que estas programando y no sabes porque se genera, algo esta mal y seguramente es algo estupido pero no te das cuenta que es porque estas cansado o simplemente no estas tan concentrado. Te vas a dormir, estas pensando en cualquier cosa, luego te pones a pensar en eso y por arte de magia Bingo! te sabes como resolverlo!. Te levantas y vas a resolver el bug o te anotas en el celular lo que tenes que hacer por la mañana.
A mas de uno estoy seguro que le ha pasado. Desde esas experiencias, me di cuenta que lo mejor que uno puede hacer cuando no puede resolver algo es despejarse un tiempo, salir a caminar, descansar y cuando vuelves a enfocarte en el problema ya lo ves desde otra perspectiva y logras resolverlo.
Es mas, no es ningun metodo nuevo, todos los genios de la historia de la humanidad, no por coincidencia les gustaba salir a caminar o a andar en bicicleta cuando estaban en medio de algo a resolver.
Cuantas veces me habrá pasado... pf jajaja
|
|
|
378
|
Programación / Programación C/C++ / Re: No mostrar decimales en Visual C
|
en: 26 Enero 2013, 18:20 pm
|
Hola josejs, puedes usar un cast a int para truncar esos decimales de la siguiente forma: metros=(int)(altura/100);
Una vez hecho ese cast supongamos que tuviesemos los siguientes datos: Tendríamos con lo dicho anteriormente esta operación: metros = (truncar)(385/100) todo esto es igual a 3 Bien eso lo tenemos. Ahora para sacar los centímetros que quedan, en C++ y en C con los tipos siguientes: No se puede hacer la operación módulo directamente con el operador '%'(ya que no dá el resultado correcto como puedes comprobar), hay que hacerlo con la siguiente función: double fmod ( double numerator,double denominator ); float fmod (float numerator,float denominator ); long double fmod (long double numerator, long double denominator );
Referencia ~~> http://www.cplusplus.com/reference/cmath/fmod/Por lo tanto el código quedaría así: metros = (int)(altura/100); centimetros = fmod(altura,100);
Además tienes que añadir este archivo de cabecera para la función 'fmod': #include <cmath>
Lo que me parece bastante extraño es que el compilador no te haya dicho nada. ¡Un saludo!
|
|
|
|
|
|
|