elhacker.net cabecera Bienvenido(a), Visitante. Por favor Ingresar o Registrarse
¿Perdiste tu email de activación?.

 

 


Tema destacado: Entrar al Canal Oficial Telegram de elhacker.net


  Mostrar Mensajes
Páginas: 1 ... 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 [37] 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 ... 132
361  Programación / Programación C/C++ / Re: encontrar el ultimo valor de la matriz recorrida en: 9 Marzo 2014, 18:37 pm
Me quito el sombreo "maestro", pequeño saltamontes se descubre ante ti.

...Y no, no estoy por la labor de aprender comandos y más comandos tipo MS.DOS. Como te dije, ya pasé por esa etapa y, al fin y al cabo, seguimos teniendo la consola en Windows. Pero no dejo de reconocer que es más rápido el sistema de comandos, una vez que te aprendes los cientos de órdenes posibles ......

Por cierto, ¿por qué usar pastebin y no colgarlo directamente?. Así permanece por los tiempos de los tiempos. Ya sé que es un pelín largo, al menos para mi gusto, pero tampoco tanto.

Un fuerte abrazo campeón.





¡¡¡¡ Saluditos! ..... !!!!


362  Programación / Programación C/C++ / Re: Recibir int seguro en: 9 Marzo 2014, 18:15 pm

Lo de un número fijo era por lo de las tarjetas de crédito y cosas así. Como en este código, sencillo pero muy funcional ... y sólo admite un número determinado de caracteres, si son menos  espera hasta que se complete y no da opción de más:

Código
  1. /*Crear un programa que pida al usuario su contraseña (numérica).
  2. Deberá terminar cuando introduzca como contraseña el número
  3. 5879, pero
  4. volvérsela a pedir teniendo cuatro intentos.*/
  5. #include <stdio.h>
  6. #include <stdlib.h>
  7.  
  8. int main( void )
  9. {
  10.    char clave [5];
  11.    int i,clave_num,intentos=0,DIGITOS=4;
  12.    do
  13.    {
  14.        printf ("\n\n\n\Presione una tecla para continuar: ");
  15.        fflush (stdout);
  16.        getch ();
  17.        system ("cls");
  18.        fflush (stdout);
  19.        printf ("\n\n\n   INTRODUZCA LA CLAVE  entera (cuatro digitos) \n\n\n");
  20.        printf ("Teclea la clave (1122 par salir) y presione enter para salir: ");
  21.        fflush (stdout);
  22.        for (i=0;i<DIGITOS;i++){
  23.            clave [i] =getch();
  24.            printf("*");
  25.            fflush (stdout);
  26.        }
  27.    clave [4] ='\0';
  28.    printf ("\n\n\t\t\tLA CLAVE INTRODUCIDA ES :%s",clave );
  29.    fflush (stdout);
  30.    printf ("\n\n\t\t\tLA CLAVE EN ASCII es  : ");
  31.    fflush (stdout);
  32.    for (i=0;i<4;i++){
  33.                printf ("%d - ",clave[i] );
  34.                fflush (stdout);
  35.            }
  36.  
  37.    intentos++;
  38.    clave_num = atoi (clave);
  39.    printf ("%d \n",clave_num);
  40.    if (intentos==3){
  41.            printf ("\n\n\t\tMe quedo con la tarjeta,,AGURRRRRRRRRRR\n\n");
  42.            exit (0) ;
  43.        }
  44.    }
  45.    while (clave_num!=5879);
  46.    printf ("\n\n\n\HASTA OTRA OCASION\n\n\n");
  47.    return 0;
  48. }

Como ves hay más formas de limitar el número de caracteres que los expuestos anteriormente. Este en particular el anterior "me llena", nada de tener que limpiar buffer ni cosas por el estilo.

Y perdón por el uso de getch() pero en el estándar de C no hay ninguna función similar, a no ser que se recurra a getchar() pero con una rápida limpieza de pantalla y aún así se pierden los otros datos impresos.

A mí personalmente el que fgets "meta" un retorno de carro en las cadenas me da un no sé qué .......

Y por cierto, aunque es otro tema, te he echado de menos en el hilo de los rombos. Está bastante animado y creo que aún no se ha acabado. Yo al menos me guardo un as en la manga .... y en C++ para variar.[/size]

¡¡¡¡ Saluditos! ..... !!!!


363  Programación / Programación C/C++ / Re: [C] Rombo con asteriscos en: 9 Marzo 2014, 17:39 pm
Acepto el reto, jeje (claro, en un nuevo post) ...
[/b]

Pues a por él, pero eso sí en forma de triángulo isósceles. La forma clásica, vamos.

Ya que te lanzo el guante te dejo que elijas "armas", es decir que empieces el tema cuando te "sientas preparado". ..... es broma, ¿ehh..?.


¡¡¡¡ Saluditos! ..... !!!!



364  Programación / Programación C/C++ / Re: encontrar el ultimo valor de la matriz recorrida en: 9 Marzo 2014, 08:18 am
COOL !!!!!!!!!!!
...................................................
Leo, se me ocurre que una forma de ampliar el programa, sería habilitar las teclas de flecha, para uno poder conducir la pelota por en medio de los obstáculos, algo como mini-pinball. Me ofrecería a hacer algo de esa parte, puesto que ya tú ya hiciste lo primero, jeje (complementarnos en vez de competir) ....


¡¡¡Eso es hacer trampas!!!

Desde que encuentre un hueco me pongo a ello. Lo que pasa es que las API de Windows son muy .... muy ...oscuras.

Podía haber usado conio2.h, que tengo instalada y en alguna que otra ocasión uso,  para el color y el gotoxy ......pero paso de regresar al pasado.

Perdona que no ponga nada en Linux pero ya pase por el MS-DOS y paso de dar ni un pasito atrás, con perdón para sus seguidores.


¡¡¡¡ Saluditos! ..... !!!!


365  Programación / Programación C/C++ / Re: [C] Rombo con asteriscos en: 9 Marzo 2014, 08:04 am

Vamos, con matrices.

Ahí va una con el borde:




Código
  1. /** BORDES **/
  2. #include <stdio.h>
  3.  
  4. int main(){
  5.  int i=0,j,k=1,a=21;
  6.  
  7.  /*do{
  8.     printf("\nBase del rombo(numero impar positivo): \n");
  9.     scanf("%d",&a);
  10.     }while ( a <=0 || (a % 2) == 0);*/
  11.    char A[a+4][a+4],cad[]="L E O S A N S A N";
  12.    for ( i=0;i<=a+4;i++)
  13.      for ( j=0;j<=a+4;j++)
  14.        A[i][j]='0';
  15.    A[0][a/2]='*';
  16.    i=1;
  17.    while (i<=a/2){
  18.      A[i][(a/2)-i]=A[i][i+(a/2)]='*';
  19.      i++;
  20.    }
  21.    k=i;
  22.    while (i>=(a/2)+1 && i<=a){
  23.      k--;
  24.      A[i][(a/2)+1-k]=A[i][(a/2)+k-1]='*';
  25.      i++;
  26.    }
  27.    if (a>20){
  28.      for ( i=(a/2)-8,k=0;i<(a/2)+10;i++,k++)
  29.        A[i][22]=cad[k];
  30.    }
  31.  
  32.    putchar ('\n');
  33.    for ( i=0;i<a;i++){
  34.      printf("\t\t");
  35.      for ( j=0;j<a+2;j++){
  36.         if (A[i][j]=='0' )
  37.            printf("%c",' ');
  38.          else
  39.            printf("%c",A[i][j]);
  40.      }
  41.      putchar ('\n');
  42.    }
  43.    return 0;
  44. }

Y por qué no en positivo y negativo:


Código
  1. #include <stdio.h>
  2.  
  3. int main(){
  4.  int i=0,j,k=1,a=21;
  5.  /*do{
  6.     printf("\nBase del rombo(numero impar positivo): \n");
  7.     scanf("%d",&a);
  8.     }while ( a <=0 || (a % 2) == 0);*/
  9.    char A[a+1][a+1];
  10.    for ( i=0;i<=a;i++)
  11.      for ( j=0;j<=a;j++)
  12.        A[i][j]='0';
  13.    A[0][a/2]='*';
  14.    i=1;
  15.    while (i<=a/2){
  16.      for ( j=(a/2)-i;j<=i+(a/2);j++){
  17.        A[i][j]='*';
  18.      }
  19.      i++;
  20.    }
  21.    k=i;
  22.    while (i>=(a/2) && i<=a){
  23.      --k;
  24.      for ( j=(a/2)+1-k;j<(a/2)+k;j++)
  25.        A[i][j]='*';
  26.      i++;
  27.    }
  28.    /** EN POSITIVO **/
  29.    for ( i=0;i<=a;i++){
  30.      printf("\t\t");
  31.      for ( j=0;j<a;j++){
  32.         if (A[i][j]=='0')
  33.            printf("%c",' ');
  34.          else
  35.            printf("%c",A[i][j]);
  36.      }
  37.      putchar ('\n');
  38.    }
  39.    putchar ('\n');
  40.    /** EN NEGATIVO **/
  41.    for ( i=0;i<=a;i++){
  42.      printf("\t\t");
  43.      for ( j=0;j<a;j++){
  44.         if (A[i][j]=='0')
  45.            printf("%c",'*');
  46.          else
  47.            printf("%c",' ');
  48.      }
  49.      putchar ('\n');
  50.    }
  51.    return 0;
  52. }

He preferido hacer dos códigos en lugar de uno con funciones para los posibles seguidores de este tema .... y paso de traslaciones, empiezo a estar saturado de tanto rombo. ¿Alguien se anima a empezar un nuevo tema con el triángulo de Pascal o Tartaglia?

¡¡¡¡ Saluditos! ..... !!!!


366  Programación / Programación C/C++ / Re: Matriz Dinamica en c++. Como rellenarla en coordenadas especificas? en: 9 Marzo 2014, 04:14 am

Tienes mal la introducción de los puntos.Tienes que"captar" las coordenadas a y b donde colocas las bombas, no darle valor a M[a] ya que sabes que es '*'.

Algo parecido a lo que te propuse en mi código:


Código
  1. ................
  2. cout << "\nIntroduzca numero de minas (numero):";
  3.  cin >> numero;
  4.  for (int i = 0; i < numero; i++){
  5.    cout << "\nColocando la mina : "<<i+1<<endl;
  6.    do{
  7.      cout << "Introduzca fila (1-numero): ";
  8.      cin >> fil;
  9.    }while(fil<1 || fil>dim);
  10.    fil=fil-1;
  11.  
  12.    do{
  13.      cout << "Introduzca columna (1-numero): ";
  14.      cin >> col;
  15.    }while(col<1 || col>dim);
  16.    col=col-1;
  17.    Matriz[fil][col]='*';
  18.    cout<<"\tM["<<fil+1<<","<<col+1<<"]="<<Matriz[fil][col]<< "\n\n";
  19. ...............................................
  20.  

donde fil=a y col=b. Ya sabes que Matriz[fil][col]='*'.



¡¡¡¡ Saluditos! ..... !!!!



367  Programación / Programación C/C++ / Re: Recibir int seguro en: 8 Marzo 2014, 19:16 pm
Claro, el "desbordamiento de buffer" es un problema típico en la programación, y que por supuesto debemos evitar.

Para C (en C++ el tamaño del arreglo se ajusta automáticamente) una solución sería usar fgets
...................................

Tiene una pequeñita pega el "rollo" de código que empleas:

* Si introduces 12 te lo da como bueno y ¿no era de tres dígitos el número a introducir?.

* Si introduces 123456 te da como bueno el 123 y ¿no es posible que se hallan equivocado al introducir los tres primeros dígitos?.

Reconozco que mi propuesta no es tan completa y compleja como la que propone ivancea96 pero sirve para estos casos de "andar por casa" y para hacerlo todo a "pelo" calculo hasta la longitud con mi propia función, más que nada por variar ya que antes utilice isdigit:


Código
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #define MAX_DIGITOS  100
  4.  
  5. int comprobar_cadena_como_numero (char numero[MAX_DIGITOS]);
  6. int longitud_cadena (char cadena[MAX_DIGITOS]);
  7. /****************************************************/
  8. int main(){
  9.  
  10.  char cadena[MAX_DIGITOS];
  11.  do{
  12.    printf("\nIntroduce un numero entero de cinco digitos: ");
  13.    scanf("%s",&cadena);
  14.    while (getchar()!='\n');
  15.    }while (comprobar_cadena_como_numero(cadena)!=2 || longitud_cadena(cadena) !=5);
  16.    printf("\nentero: %d\n",atoi (cadena));
  17.    return EXIT_SUCCESS;
  18. }
  19. /****************************************************/
  20. int comprobar_cadena_como_numero (char cadena[MAX_DIGITOS]){
  21.    int i;
  22.    for (i=0;cadena[i];i++)
  23.       if (cadena[i]<'0' || cadena[i]>'9')
  24.            return 1;
  25.    return 2;
  26. }
  27.  
  28. /****************************************************/
  29. int longitud_cadena (char cadena[MAX_DIGITOS]){
  30.    int i;
  31.    for (i=0;cadena[i];i++);
  32.    return i;
  33. }
  34. /****************************************************/
  35.  

Ya sé que tiene una pequeña pega pero este código sólo admite cindo dígitos, ni uno más ni uno menos.

Y todo esto es para pasar el tiempo y compartir conocimientos. Yo sigo aprendiendo de todos ustedes. Gracias.


¡¡¡¡ Saluditos! ..... !!!!


368  Programación / Programación C/C++ / Re: tableros en: 8 Marzo 2014, 18:46 pm
Interesante la simplificación de leosansan, ventajas del trabajo en equipo
.................................................
Ahora otra vez leo, me parece interesante tu simplificación del código, pero explícamente la aritmética usada de 12, 18, 36, etc ..... No entiendo esas fórmulas, y creo que también hubiera sido bueno comentariar esa explicación en el programa, los demás no somos adivinos jejejeje (broma)


¿Es una coña,no?.

Por si acaso simple cuestión de mates ,,,,sólo te contaré que se corresponden con posiciones centrales de los espacios en blanco, ni a la derecha ni a la izquierda de las paredes laterales, centrados ..... haz números ..... siempre que a mi no se me haya ido el baifo !!!. No olvides que se trataba de no hacerle la tarea al que inicio el tema, así que algo de oscurantismo es inevitable.


¡¡¡¡ Saluditos! ..... !!!!



.
369  Programación / Programación C/C++ / Re: Recibir int seguro en: 8 Marzo 2014, 16:00 pm
Gracias ahora consegui hacer lo.
.......................................................
Pero una pregunta. El código de c que utiliza char[] no daría error si se introduce un valor mayor que el size?
Muchas gracias

¿Y quién es el animalito que al pedirle un entero introduce más de 100 dígitos?.

Claro que haberlos "haylos" pero todo sería cuestión de hacer una limpieza adicional del buffer.


¡¡¡¡ Saluditos! ..... !!!!


370  Programación / Programación C/C++ / Re: [C] Rombo con asteriscos en: 8 Marzo 2014, 15:50 pm

Vaya, si que os entreteneis con esto jajajajaja.
...............................................................

Gracias a todos por ponerme tantos ejemplos, asi tengo donde elegir y comparar las lógicas de cada uno.

Un saludo

Pues si que ha sido entretenido.

Y aunque do-while me lo piso, no me resisto a poner el caso con memset. Es ligeramente diferente al suyo ya que no uso recurrencia y es ligeramente más cortito:


Código
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <string.h>
  4.  
  5. int main(void){
  6.  int i,j,a;
  7.  do{
  8.    printf("\nBase del rombo(numero impar positivo): \n");
  9.    scanf("%d",&a);
  10.    }while ( a <=0 || (a % 2) == 0);
  11.  char *str = malloc(2*a+1);
  12.  for (i = -a/2; i <= a/2; i++){
  13.    j=i;
  14.  if (i>0)
  15.    j=-i;
  16.    memset (str,' ',(a/2)-j);/** relleno izquierda con espacios **/
  17.    memset (str+(a/2)-j, '*',2*((a/2)+j)+1); /** relleno derecha con asteriscos **/
  18.    printf ("%s\n",str);
  19.    memset (str,0,2*a+1);/** hago nula la cadena para volver a usarla **/
  20.  }
  21.  free(str);
  22.  return EXIT_SUCCESS;
  23. }

¡¡¡¡ Saluditos! ..... !!!!



Páginas: 1 ... 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 [37] 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 ... 132
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines