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 ... 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 [109] 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 ... 132
1081  Programación / Programación C/C++ / Re: Ordenación de tablas en: 1 Enero 2013, 21:30 pm
Citar
Según tú, el problema empieza con un: tengo una tabla asi
1 2 3 4
4 3 1 3
2 1 4 2
3 4 2 1

Pues el array "num" consta de los elementos de esa matriz:1,2,3,4. Lo uso porque si siempre fuera así el código podría ser más sencillo, pero con el uso del array me cubro las espaldas en caso de que los elementos de esa matriz no sean ni esos ni consecutivos.
Saluditos!. .....  :rolleyes: :rolleyes: :rolleyes: :rolleyes: :rolleyes: :rolleyes:
1082  Programación / Programación C/C++ / Re: Problema cadenas en: 1 Enero 2013, 18:56 pm
No funciona el enlace. Mira si lo puedes corregir.
Saluditos!.
.....  :rolleyes: :rolleyes: :rolleyes: :rolleyes: :rolleyes: :rolleyes: :rolleyes:
1083  Programación / Programación C/C++ / Re: Ordenación de tablas en: 1 Enero 2013, 18:55 pm
Muchisimas gracias! Pero podrias poner que hace cada cosa? :| Es que no lo acabo de entender  :-\
Lo mejor es que corras el programa y "voila" hace lo que te pide.
Código
  1. int num[]={1,2,3,4};<==array con los numeros de la matriz inicial.
  2. ............................
  3. for (k=0;k<4;k++){
  4.      p++; <==inicio e incremento el array "num"
  5.        for (i=0;i<4;i++){
  6.            for (j=0;j<4;j++){
  7.               if (v1[i][j]==num[p]) { <==voy cogiendo los distintos numeros de la matriz: el 1,2,3,4
  8.                  b[k][j]=v1[i][j]; <==para cada num lo coloco en la linea correspodiente:los 1 en la primera, los 2 en la segunda ......
  9.                  d[k][j]=v2[i][0]; <==veo las coincidencias con la matriz de control, la de ceros y unos y los meto en otra matriz
  10.               }
  11.            }
  12.         }
  13.    }
  14. Pero como te comente, corre el programa y veras que te da la matriz
  15. "b"         "d"
  16. 1 1 1 1      0011
  17. 2 2 2 2      0010
  18. 3 3 3 3      1101
  19. 4 4 4 4      1100
  20.  
Saluditos!. .............  :rolleyes: :rolleyes: :rolleyes: :rolleyes: :rolleyes: :rolleyes: :rolleyes: :rolleyes:
1084  Programación / Programación C/C++ / Re: Ordenación de tablas en: 1 Enero 2013, 15:46 pm
Tengo una tabla asi
1 2 3 4
4 3 1 3
2 1 4 2
3 4 2 1
Y otra que es
0
1
0
1
Donde cada elemento de la 1 fila de corresponde al 0, de la segunda al 1, y asi (cada columna de la 1 tabla son experimentos diferentes)
Tengo que ordenar cada columna de menor a mayor y a la vez crear otra tabla de 4x4 con las etiquetas (0 y 1) ordenadas en cada experimento.
Se quedaria
1 1 1 1      0011
2 2 2 2      0010
3 3 3 3      1101
4 4 4 4      1100
¿Serian tres for anidados?

Pues sí, son tres for anidados con una condición. Te he puesto el array "num" para un caso más general en que los números de la matriz no sean consecutivos:
Código
  1. #include <stdio.h>
  2.  
  3. int main()
  4. {
  5.    int i,j,k,p=-1;
  6.    int num[]={1,2,3,4};
  7.    int v1[4][4]={{1,2,3,4},
  8.                 {4,3,1,3},
  9.                 {2,1,4,2},
  10.                 {3,4,2,1}},
  11.       v2[4][1]={0,
  12.                 1,
  13.                 0,
  14.                 1};
  15.    int b[4][4]={0},d[4][4]={0};
  16.    for (k=0;k<4;k++){
  17.      p++;
  18.        for (i=0;i<4;i++){
  19.            for (j=0;j<4;j++){
  20.               if (v1[i][j]==num[p]) {
  21.                  b[k][j]=v1[i][j];
  22.                  d[k][j]=v2[i][0];
  23.               }
  24.            }
  25.         }
  26.    }
  27.   for (i=0;i<4;i++){
  28.      for (j=0;j<4;j++){
  29.         printf ("%d  ",b[i][j]);
  30.      }puts ("\n");
  31.   }
  32.   puts ("\n");
  33.   for (i=0;i<4;i++){
  34.      for (j=0;j<4;j++){
  35.         printf ("%d  ",d[i][j]);
  36.      }puts ("\n");
  37.   }
  38.    return  0;
  39. }
  40.  
Saluditos!. .....   :rolleyes: :rolleyes: :rolleyes: :rolleyes: :rolleyes: :rolleyes: :rolleyes: :rolleyes:
1085  Programación / Programación C/C++ / Re: Tratamiento de dos tablas a la vez en: 31 Diciembre 2012, 19:24 pm

Seria calcular la distancia euclidea como si fuesen ejes coordenados, es decir
la raiz de la suma de las diferencias al cuadrado (en una funcion)
No pongo codigo porque no sé por donde empezar, es decir, que bucle hago para hacer esa relacion?
A ver si así te aclaras un poquito más. te he puesto un par de cosas para que veas como va el código, aunque sólo con la parte de CALCULO DE CUADRADO DE DISTANCIA tienes lo que realmente quieres:
Código
  1. #include <stdio.h>
  2. #include <math.h>
  3. int main()
  4. {
  5.   int v1[3][3]={{1,2,3},
  6.                 {4,5,6},
  7.                 {7,8,9}},
  8.       v2[3][3]={{2,4,8},
  9.                 {6,9,18},
  10.                 {3,4,5}}, i,j,k;
  11.   float d[3][3]={0};
  12.   /******ESTO PARA VER COMO SE RESTAN LAS LINEAS*************/
  13.   for (i=0;i<3;i++){
  14.      for (j=0;j<3;j++){
  15.         for (k=0;k<3;k++){
  16.            d[i][j]+=v2[i][k]-v1[j][k];
  17.         }
  18.      }
  19.   }
  20.   for (i=0;i<3;i++){
  21.      for (j=0;j<3;j++){
  22.         printf ("%g  ",d[i][j]);
  23.      }puts ("\n");
  24.   }
  25.   puts ("\n");
  26.   /*****************CALCULO DE CUADRADO DE DISTANCIAS****ESTO SOLO YA TE VALE****************/
  27.  
  28.   for (i=0;i<3;i++){
  29.      for (j=0;j<3;j++){d[i][j]=0;
  30.         for (k=0;k<3;k++){
  31.            d[i][j]+=pow (v2[i][k]-v1[j][k],2);
  32.         }/* d[i][j]=sqrt (d[i][j]);<== para calcular aqui las distancias y quitando CALCULO DE DISTANCIAS */
  33.      }
  34.   }
  35.   for (i=0;i<3;i++){
  36.      for (j=0;j<3;j++){
  37.         printf ("%g  ",d[i][j]);
  38.      }puts ("\n");
  39.   }
  40. /*****************CALCULO DE DISTANCIAS********************/
  41.  
  42.   for (i=0;i<3;i++){
  43.      for (j=0;j<3;j++){
  44.            d[i][j]=sqrt (d[i][j]);
  45.      }
  46.   }
  47.   for (i=0;i<3;i++){
  48.      for (j=0;j<3;j++){
  49.         printf ("%g  ",d[i][j]);
  50.      }puts ("\n");
  51.   }
  52.   return 0;
  53. }
  54.  
Saluditos!. ... y Feliz 2013  :rolleyes: :rolleyes: :rolleyes: :rolleyes: :rolleyes: :rolleyes:
1086  Programación / Programación C/C++ / Re: Como limitar un resultado en un ordenamiento de Burbuja en: 27 Diciembre 2012, 17:32 pm


 seria de esta forma ¡ ¡ ¡

Código:
//MOSTRAMOS LOS NUMEROS ORDENADOS///////////////aca puse esto mientras
cout<<"\nRESULTADOS EN ORDEN\n";
////
    for(int i = 0; i < contador; i++){

        if (resultados[i]>=80) break;
         cout <<resultados[i])<<" ";
}

Saluditos!. :rolleyes: :rolleyes: :rolleyes: :rolleyes:
1087  Programación / Programación C/C++ / Re: Como limitar un resultado en un ordenamiento de Burbuja en: 27 Diciembre 2012, 16:04 pm

 1 2 3 4 5 6 9 10 45 68 77 79,,no sigue se para en el 79 y acaba

Primero se tienen que ordenar todos, ya que si pones la condición en el "proceso" de ordenamiento y se encuentra con 80 se pararía.
Es decir, la condición la impondrías en la "impresión" de los números ordenados:
Código
  1. for (i=0; i< Tam; i++) {
  2.        if (array[i]>=80) break;
  3.         cout <<array[i])<<" ";
  4. }
Saluditos!.        
1088  Programación / Programación C/C++ / Re: Duda sobre utilización de variables en: 20 Diciembre 2012, 16:44 pm

Lo que quiero es no tener que ir guardando en las variables una por una, sino que num vaya tomando valor 1,2,3...etc.
Código
  1. #include <stdio.h>
  2.  
  3. main(){
  4.  int num[5]={0};
  5.  int i=0;
  6.  for(i=0;i<5;i++){
  7.    printf("\nValor %d:",i+1);
  8.    num[i]=i+1;
  9.    printf("Valores: %d", num[i]);
  10.  }
  11. }
  12.  
Saluditos!.
1089  Programación / Programación C/C++ / Re: lograr guardar resultados en un txt bucles o for ? en: 17 Diciembre 2012, 21:36 pm
Bueno esto no serviria para hacer lo que busco ?
Citar
Si lo que buscas es guardar las combinaciones en el fichero "numeros.txt" el código que te puse en el anterior post -un poco más arriba de este- lo hace. El fichero de txt lo encuentras en la carpeta donde tengas guardado el programa.
Saluditos!.
1090  Programación / Programación C/C++ / Re: lograr guardar resultados en un txt bucles o for ? en: 16 Diciembre 2012, 22:11 pm

Saluditos!.
Citar

P.D: Recuerda que sólo va para combinaciones de n elementos tomados de tres en tres los otros casos están pendientes de implementar.


Páginas: 1 ... 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 [109] 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 ... 132
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines