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

 

 


Tema destacado: Tutorial básico de Quickjs


  Mostrar Mensajes
Páginas: 1 ... 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 [20] 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 ... 132
191  Programación / Programación C/C++ / Re: Problema en variable int en: 30 Abril 2014, 15:08 pm
.......................................................................
Pifiarla?? yo creo que cuando se hacen propuestas de estas tampoco es plan de que nadie exija que la solución funcione a la perfección en todos los casos... Yo con mi código hice un par de pruebas... si fuese para un desarrollo real le programaría una tira de pruebas bastante contundente.

Además, si alguien cree que puede hacerlo mejor, en vez de criticar, que exponga su solución... así además aprenderemos los demás.

¿No?

Por cierto, me falta alguien en esta conversación con toques matemáticos... qué ha sido de yoel_alejandro??


Gracias, muchas gracias eferion por tus palabras de comprensión.

Y es cierto, hace días que yoel_alejandro no aparece por el foro, que no "forro" y la verdad es que se hecha de menos sus aportaciones en C, y especialmente, sus puntos de vista matemáticos Con eso de que es de Venezuela espero sinceramente que no le haya pasado nada y que su ausencia se deba a cuestiones de trabajo que tal como están las cosas le vendría muy bien, como a todos, claro.

¡Un fuerte saludo!.


192  Programación / Programación C/C++ / Re: Problema en variable int en: 30 Abril 2014, 14:15 pm
¿Y hacerte una clase para manejar números grandes?

...............................................................................

Si estás programando en C el tema de las clases ya no te sirve... pero aún así sigue habiendo opciones.


Bueno si se trata de sumar números grandes en C, aunque no es necesaria, mejor con una función por si nos da por ampliar a resta, producto, etc y con arrays.

Y como comentó eferion:



Como es de esperar... ni está optimizada ni completa... está hecha en un rato para satisfacer el insaciable apetito de vangodp... pero vale de ejemplo.


Todo por un colega como vangodp, ahí va mi más que modesta propuesta en C:

Código
  1. #include <stdio.h>
  2. #include <string.h>
  3.  
  4. #define MAX_DIGITOS 200
  5.  
  6. void suma (char a[], char b[], char c[]){
  7.  int i,temp,residuo=0,lon_a,lon_b,dif;
  8.  lon_a = strlen(a);
  9.  lon_b = strlen(b);
  10.  if (lon_a > lon_b){
  11.    dif=lon_a-lon_b;
  12.    for (i=lon_b-1; i >=0;i--)
  13.      b[i+dif]=b[i];
  14.    for (i=0; i < dif;i++)
  15.        b[i]='0';
  16.  }
  17.  else if (lon_b > lon_a){
  18.    dif=lon_b-lon_a;
  19.    for (i=lon_a-1; i >=0;i--)
  20.      a[i+dif]=a[i];
  21.    for (i=0; i < dif;i++)
  22.        a[i]='0';
  23.  }
  24.  for (i=strlen(a)-1; i>=0;i-- ){
  25.    temp = a[i]-'0' + b[i]-'0' + residuo;
  26.    c[i+1]=temp%10+'0';
  27.    residuo=temp/10;
  28.  }
  29.  c[0] = residuo + '0';
  30.  if (c[0]=='0'){
  31.    for (i=0; i < strlen(a);i++ ){
  32.      c[i]=c[i+1];
  33.    }
  34.    c[strlen(a)]='\0';
  35.  }
  36.  c[strlen(a)+1]='\0';
  37. }
  38.  
  39. int main(void){
  40.  char a[MAX_DIGITOS] = /*  "99" */ /* "99" */ "123456123456123456123456123456123123";
  41.  char b[MAX_DIGITOS] = /* "199" */ /* "99" */  "983456123456123456123456123456123123";
  42.  char c[MAX_DIGITOS+1];
  43.  suma (a,b,c);
  44.  printf ("\n  %s +\n  %s=\n\n %s\n ",a,b,c);
  45.  return 0;
  46. }

La verdad que viendo el código de eferion el mio es como pobre, demasiado cortito.

Y sí, ya, sé debía usar memoria dinámica pero sólo quería algo rapidito para vangodp, ya si procede lo mejoro con las observaciones que aporten. E insisto, es un código modestito, sólo pretendía sumar un par de números grandes.

.....Bueno, está bien, lo mejoro. ¿Cómo?, pues lo de la memoria dinámica lo dejaré otra ocasión, ahora se me apetece otra cosa .......¿y si intentamos que los número grandes puedan estar en cualquier base de 2 a 36?. Es decir poder sumar números grandes en decimal o binario o octal o hexadecimal o ... y así sumar números grandes que estén entre las ya mencionadas bases de 2 a 36, los dos números en la misma base, claro...... otra cosa a mejorar. :)

De antemano aclaro que para bases superiores  a 10 no lo tengo del todo testado, pero creo que sí, que funciona:


Código
  1. #include <stdio.h>
  2. #include <string.h>
  3.  
  4. #define MAX_DIGITOS 300 /* o 3000*/
  5. #define DIGITOS   "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"
  6. #define BASE  16
  7.  
  8. void suma (char a[], char b[], char c[]){
  9.  int i,temp,temp_a,temp_b,residuo=0,lon_a,lon_b,dif,digit;
  10.  lon_a = strlen(a);
  11.  lon_b = strlen(b);
  12.  if (lon_a > lon_b){
  13.    dif=lon_a-lon_b;
  14.    for (i=lon_b-1; i >=0;i--)
  15.      b[i+dif]=b[i];
  16.    for (i=0; i < dif;i++)
  17.        b[i]='0';
  18.  }
  19.  else if (lon_b > lon_a){
  20.    dif=lon_b-lon_a;
  21.    for (i=lon_a-1; i >=0;i--)
  22.      a[i+dif]=a[i];
  23.    for (i=0; i < dif;i++)
  24.        a[i]='0';
  25.  }
  26.  for (i=strlen(a)-1; i>=0;i-- ){
  27.    if(a[i]-48>9 )
  28.      temp_a = a[i] -55 ;
  29.    else
  30.      temp_a = a[i] - '0';
  31.    if(b[i]-48>9)
  32.      temp_b = b[i] -55;
  33.    else
  34.      temp_b = b[i] - '0';
  35.    temp = temp_a + temp_b + residuo;
  36.    digit = DIGITOS [temp % BASE];
  37.    if (digit<10)
  38.      c[i+1]=DIGITOS [temp % BASE] + '0';
  39.    else
  40.      c[i+1]=DIGITOS [temp % BASE] ;
  41.    residuo = temp / BASE;
  42.  }
  43.  c[0] = residuo + '0';
  44.  if (c[0]=='0'){
  45.    for (i=0; i < strlen(a);i++ )
  46.      c[i]=c[i+1];
  47.    c[strlen(a)]='\0';
  48.  }
  49.  c[strlen(a)+1]='\0';
  50. }
  51.  
  52. int main(void){
  53.  /** ¡¡¡ NO OLVIDES CAMBIAR LA BASE DE (2-36) EN #DEFINE¡¡¡ **/
  54.  /** Tienes tres ejemplos: base 16, base 2, base 10 **/
  55.  char a[MAX_DIGITOS] = "A33A15FADBC9"  /*"1001001110111001" */ /*"123456123456123456123456123456123123"*/;
  56.  char b[MAX_DIGITOS] = "FFC593C5BA33A" /*"1001001110111001" */ /* "983456123456123456123456123456123123"*/;
  57.  char c[MAX_DIGITOS+1];
  58.  suma (a,b,c);
  59.  printf ("\n  %s +\n  %s=\n\n %s\n ",a,b,c);
  60.  return 0;
  61. }
  62.  

Y para que no digan, explico brevemente lo que hace el código:

* Calcula los tamaños de  ambos números y diferencio al de mayor tamaño del de menor.

* Al más pequeño lo relleno con ceros a la izquierda, previo movimiento hacia la derecha de todos sus dígitos para hacer espacio al principio a los ceros, hasta igualar las cifras del mayor.

* Y ya casi está, voy sumando los dígitos de cada uno de los dos números big y si suman más de 10, supuesto están en decimal, pongo el resto como dígito y "me llevo una", eso es el residuo que se sumará, si procede a los dos dígitos siguientes.

* Y para que quede bonito, si el primer caracter del resultado de la suma es cero lo quito moviendo  todos sus dígitos a la izquierda y acortando el tamaño en uno.

La intención es lo que cuenta, como suele decirse. De antemano disculpas si la he pifiado en algo,cosa que espero no haya ocurrido pero ....somos humanos y las prisas no son buenas consejeras. Así que si detectan bugs, porfi avisar.

Y sí, ya sé, el primer código podría usarlo para bases de 2 a 10 sin más que cambiar el "10" que aparece en el mencionado código , por "base" y esta tomar valores de 2 a 10, pero me apetecía ir más allá de la base en decimal xD.


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


193  Programación / Programación C/C++ / Re: duda ejercicio, empezando con C en: 29 Abril 2014, 00:28 am

Algo como esto:
Código
  1. .................
  2. }while(x!=9999);
  3.    if (contador!=1)
  4.      printf("\n\nEl promedio total es: %f",promedio);
  5.    return 0;
  6. }


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


194  Programación / Programación C/C++ / Re: Problema en C [Ayuda] en: 28 Abril 2014, 23:10 pm
Eso también lo comenté en el primer mensaje :)

Sorry, se me paso por alto.

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


195  Programación / Programación C/C++ / Re: Problema en variable int en: 28 Abril 2014, 23:06 pm
Hola gente :)
.................................

Código
  1. if ((numero > 99999999999999999999) && (numero < 10000000000000000)) //si numero tiene 21 caracteres
  2. {
  3. }

............................................

Salu2 meoit =)

Antes que nada revisa esas condiciones ya que no puede ser a la vez:

Código
  1. numero>99999999999999999999  y
  2. numero<10000000000000000

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


196  Programación / Programación C/C++ / Re: se ha producido una violacion de acceso a memoria dev c++ en: 28 Abril 2014, 21:25 pm
Nombres de variables poco descriptivos, nada de indentación...

Todo eso son malas prácticas que debemos editar. Voy a usar mi plugin mágico para identarte el código:


¡Secretitos en reunión es de mala educación!.

¿Vamos como activas/descargas el dichosito plugin?

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


197  Programación / Programación C/C++ / Re: Datos previo y siquiente en un arreglo en: 28 Abril 2014, 19:36 pm
A mi si que me funciona, a ver lo dejo comentado y con un ejemplo:
Código
  1. #include <iostream>
  2.  
  3. using namespace std;
  4.  
  5. const int ARRAY_LEN = 6; //numero de elementos del array
  6.  
  7. int arreglo[] = { 10, 20, 30 ,40 ,50,60};
  8. ..........................
  9.  
..................

Por un lado no es aconsejable declarar arreglo como global, no le veo el sentido y por otro lado tampoco veo declarar la longitud del array, esta vendrá determinada en este caso por su contenido: si cambias su valor a uno mayor, por ejemplo, te irás a posiciones fuera del array y, en cambio, si cambias el contenido del array, aumentándolo por ejemplo, te quedarás corto con ARRAY_LEN . Es decir para un cambio en el contenido  del array tienes que hacer dos cambios, en el array y en su longitud.

Mejor calcular la longitud del array en función de su contenido, yo lo hago tipo C, y así si cambias el array no tienes que cambiar su longitud ya que la calculas a posteriori:

Código
  1. #include <iostream>
  2.  
  3. using namespace std;
  4.  
  5. int main (void){
  6. int arreglo[] = { 10, 20, 30 ,40 ,50,60};
  7. int indice ,ARRAY_LEN = sizeof arreglo/ sizeof *arreglo;
  8. cout << "Introduzca el indice (0-" <<ARRAY_LEN-1<<"):";
  9. cin >> indice;
  10. if(indice < 0 || indice >= ARRAY_LEN) // entonces no es un indice de nuestro arreglo
  11. cout << "fuera del array" << endl;
  12. else{
  13. if(indice != 0) //si es 0 no h
  14. .........................
  15.  

Y amigo vangodp quidadito con esto:

¿¿¿Estoy perdonado???  ;D ;D ;D
Código
  1. #include <iostream>
  2. #include <windows.h>
  3. using namespace std;
  4.   ................................................
  5. system("pause>nul"); <==ESTOOOOOOOOOO
  6. return 0;
  7. }
  8.  

El "system("pause>nul")" te crea un fichero null.txt. Mejor usar getchar si lo que quieres es parar el programa.

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


198  Programación / Programación C/C++ / Re: Problema en C [Ayuda] en: 28 Abril 2014, 18:49 pm

Lo que no tiene ningún sentido es pasarle a la función "i" ya que no aporta ninguna información a la misma. Bastaría declarar int i en la función menmay y dejarla así:

Código
  1. void menmay (int vector[10], double promedio);

Código
  1. ..............
  2. menmay(vector,promedio);
  3. ..................
  4.  

Código
  1. void menmay (int vector[10], double promedio)
  2. {
  3. .............
  4. int i,j=0,k=0;
  5. .................
  6.  

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


199  Programación / Programación C/C++ / Re: Necesito un código Escaner de Puertos en C++ usando Threads en: 26 Abril 2014, 22:06 pm

Muchas Thanks, campeón.

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


200  Programación / Programación C/C++ / Re: Necesito un código Escaner de Puertos en C++ usando Threads en: 26 Abril 2014, 20:11 pm
En mi Code::Blocks, activando la opción C++11, van perfecto.

¿Qué versión de SFML tienes instalada?

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


Páginas: 1 ... 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 [20] 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 ... 132
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines