• Viernes 19 de Abril de 2024, 13:03

Mostrar Mensajes

Esta sección te permite ver todos los posts escritos por este usuario. Ten en cuenta que sólo puedes ver los posts escritos en zonas a las que tienes acceso en este momento.


Temas - NICOLASBLUES

Páginas: [1]
1
C/C++ / el poco Recomendable scanf !!
« en: Sábado 15 de Mayo de 2010, 23:26 »
Hola Gente!!

SI NO OS INTERESA EL PORQUE DE NO USARLO PUDEN PASAR AL FINAL QUE SE EXPLICA COMO SUPLANTARLO

Hoy explico  porque el uso de scanf no es recomendable..
para empesar es un error decir que un programa lee del teclado en verdad lo que hace es leer de un area de memoria llamado "buffer de teclado"  y el buffer del teclado es "buffer de linea" esto quiere decir  que los datos que provienen del teclado se insertan linea por linea y no caracter a caracter . Es por eso que cuando leemos de ahí, por más que ingresemos muchos caracteres, hasta que no ingresamos el fin de línea (enter) el programa no lee nada y se queda trabado esperando que haya algo en el buffer.

si el buffer no está vacío, sí o sí hay al menos un fin de línea;
el buffer siempre tiene un carácter de fin de línea al final.

El gran problema con scanf es que no siempre leerá el fin de linea lo que nos lleva a que el buffer quede con basura, osea con caracteres no leídos los cuales la próxima vez que invoquemos a scanf los leerá de mas esta decir que esto podría causar algunos problemas al programador.
scanf solo lee hasta que encuentre el formato que le especificamos, esto conlleva a otro gran problema ya que si nosotros le decimos que lea un entero (%i") y nosotros ingresamos 2 enteros separados por un espacio scanf solo leerá hasta encontrar el formato especificado dejando al buffer sucio con ese entero de mas
Otro problema que tenemos es que no hace ningún tipo de chequeo a la hora de verificar los datos ingresados si se le indica que se ingresara un entero y el usuario ingresa una letra esté hace una conversión a entero lo cual genera un problema.


por estas razones no es recomendable usarlo siempre se puede suplantar con algo que no ensucie el buffer para eso utilsaremos sscanf y fgets :

Código: C
  1.  
  2. #include <stdio.h>
  3.  
  4. int main()
  5. {
  6.    char nombre[20]="", entrada[81]="";
  7.    unsigned int edad=0;
  8.  
  9.    printf( "Escriba su nombre y edad, separados por un espacio:n" );
  10.    fgets(entrada, 20, stdin ); //llenamos el buffer reservando 20 caracteres y stdin es la entrada standar
  11.    sscanf( entrada, "%s %u", nombre, &edad ); //con sscanf introducimos lo que tenemos en el buffer tanto en nombre como en edad    
  12.  
  13.    printf( "Has escrito: %sn", entrada ); //lo que tenemos en el buffer
  14.    printf( "Nombre: %s. Edad: %dn", nombre, edad ); //
  15.  
  16.  

El único inconveniente que tendremos con fgets es que como bien dice
Sorancio es que si nosotros ingresamos menos caracteres los que le indicamos en el segundo parámetro inserta un fin de linea en la cadena esto representa un pequeño inconveniente con el cual lidiar pero se podría de la siguiente manera:
 
Código: C
  1. if (letra2[strlen(letra2)-1]=='n')
  2.  letra2[strlen(letra2)-1]='';
  3.  


lo cual también representa una alternativa para gets la cual no tiene control interno y provoca muchas veces problemas inesperados.



bueno eso es todo...

Saludos Cordiales

2
C/C++ / Truncar teclas C Linux
« en: Jueves 13 de Mayo de 2010, 03:44 »
Hola a todos!!

bueno tengo una pequeña duda estaba pensando en que si hay alguna manera de poder truncar o bloquear las teclas cuando se pide que se igresen datos, me explico, supongamos que se pide que se ingrese una cadena y a la hora de teclear por ejemplo la etra "n", nisiquiera se imprima en pantalla cuando la presiono... se que deve haber  alguna manera con directivas o algo asi
yo me imagino que puede ser revisando primero las letras que uno presiona con una funcion como getchar o algo asi pero no se me ocurre del todo como implementarlo
bueno espero que puedan ayudarme

os dejo Saludos.......
  

3
Cobol / porque se sigue usando cobol ¿?¿
« en: Martes 11 de Mayo de 2010, 19:37 »
por mas que me lo pregunte no entiendo porque se sigue usando cobol no conosco muchos lenguajes pero los poco que uso son 10.000 veces mucho mas legibles que este lenguaje
y por eso la gran pregunta.. porque se sigue usando?? no hay lenguajes mejores a la hora de tratar la parte contable???
o simplemente si los hay pero se sigue usando por el simple echo de quienes tienen un sistema echo en cobol les es mucho mas rentable seguir con ese sistema que renovarlo por completo???

4
C/C++ / Problema!! matriz Dinamica!!. C
« en: Lunes 10 de Mayo de 2010, 18:13 »
Hola gente!!!

bueno les cuento que estoy ante un gran dilema esto es asi:

mediante una matriz estatica de enteros de 20 x 20 hay que generar dinamicamente otra matriz cuyos elementos son todos aquellos que son unicos en la matriz estatica de 20 x 20, es decir si en la matriz estatica tenemos:
 pos[0][0]=1  
 pos[0][1]=1
 pos[0][2]=23

en la dinamica tendremos pos[0][0]=23

ya que 23 es unico en la matriz


el algoritmo responde bien hace exactamente eso pero me quedo muy confuso si alguien purde sugerir alguna manera de arreglarlo o de encararlo por otro lado seria grandioso !!


 
Código: C
  1.  
  2. #include <stdio.h>
  3. #include <stdlib.h>
  4. #include <ctype.h>
  5.  
  6. void gen_matriz (int** nuevo, int matriz[20] [20])
  7.  
  8. {
  9.     int j, k, y;
  10.     int dup;
  11.     int num_elem[20];      
  12.  
  13.     nuevo = (int**) calloc(20, sizeof(int*));
  14.  
  15.  
  16.     for (y = 0; y < 20; y++)
  17.     {      
  18.         num_elem[y] = 0;
  19.  
  20.         for (k = 0; k < 20; k++)
  21.         {
  22.             dup = 0;
  23.             j = 0;      
  24.             while ((j < 20) && !dup)    
  25.             {          
  26.  
  27.               if (k != j)
  28.               {
  29.                 dup = matriz[y][k] == matriz[y][j];            
  30.                 printf ("y=%i %i %in",y, j, dup);
  31.               }
  32.               j++;
  33.             }
  34.             printf ("dup %in", dup);
  35.             if (!dup)
  36.             {                        
  37.  
  38.                 num_elem[y]++;
  39.                 if (nuevo[y] == NULL)
  40.                   nuevo[y] = (int*) malloc(sizeof (int));
  41.                 else
  42.                   nuevo[y] = (int*) realloc(nuevo[y], num_elem[y] * sizeof (int));
  43.  
  44.                 int indice = num_elem[y] - 1;                  
  45.                 nuevo[y][indice] = matriz[y][k];                
  46.                 printf (" posicion %i %i : %in", y, k, nuevo [y] [indice]);                    
  47.  
  48.             }      
  49.         }  
  50.  
  51.     }
  52.  
  53.     for(y = 0; y < 20; y++)
  54.         for(k = 0; k < num_elem[y]; k++)
  55.             printf("nuevo[%i][%i] = %in", y, k, nuevo[y][k]);
  56. }
  57.  
  58.  

   
esta un poco desprolijo espero que se entienda

espero que me puedan ayudar saludos!!!

Páginas: [1]