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

 

 


Tema destacado: Los 10 CVE más críticos (peligrosos) de 2020


  Mostrar Mensajes
Páginas: 1 2 3 [4] 5 6 7 8 9 10 11 12 13 14 15 16 17 18
31  Programación / Programación C/C++ / Re: RETOS C++ en: 1 Octubre 2012, 21:08 pm
esta forma de estructurar el if nunca lo havia visto
y a decir verdad solo entiendo la mitad.

Si me puedes explicar el ? y el a:b. que és lo que no entendi.





Operadores ternarios busca documentación sobre ellos son bastante útiles.

EI: juntando mensajes.

RETO 12:

Código
  1. #include <iostream>
  2. #include <fstream>
  3. using namespace std;
  4. int numeroSudoku[100];
  5. bool compruebaVertical();
  6. bool compruebaCuadros();
  7. bool compruebaHorizontal();
  8.  
  9. int main(int argc,char* argv)
  10. {
  11.  
  12.    ifstream archivo("sudoku.txt");
  13.    for(int x=0;x<=80 && archivo.eof() == false;x++)
  14.    {
  15.        archivo >> numeroSudoku[x];
  16.    }
  17.    if(compruebaVertical()  && compruebaHorizontal()  && compruebaHorizontal())
  18.    {
  19.        cout << "Sudoku Valido" << endl;
  20.    }
  21.    else
  22.    {
  23.        cout << "Sudoku Invalido" << endl;
  24.    }
  25.    return 0;
  26. }
  27.  
  28. bool compruebaVertical()
  29. {
  30.    if(numeroSudoku[0] + numeroSudoku[9] + numeroSudoku[18] + numeroSudoku[27] + numeroSudoku[36] + numeroSudoku[45] + numeroSudoku[54] + numeroSudoku[63] + numeroSudoku[72] == 45 )
  31.    {
  32.        if(numeroSudoku[1] + numeroSudoku[10] + numeroSudoku[19] + numeroSudoku[28] + numeroSudoku[37] + numeroSudoku[46] + numeroSudoku[55] + numeroSudoku[64] + numeroSudoku[73] == 45 )
  33.        {
  34.            if(numeroSudoku[2] + numeroSudoku[11] + numeroSudoku[20] + numeroSudoku[29] + numeroSudoku[38] + numeroSudoku[47] + numeroSudoku[56] + numeroSudoku[65] + numeroSudoku[74] == 45 )
  35.            {
  36.                if(numeroSudoku[3] + numeroSudoku[12] + numeroSudoku[21] + numeroSudoku[30] + numeroSudoku[39] + numeroSudoku[48] + numeroSudoku[57] + numeroSudoku[66] + numeroSudoku[75] == 45 )
  37.                {
  38.                    if(numeroSudoku[4] + numeroSudoku[13] + numeroSudoku[22] + numeroSudoku[31] + numeroSudoku[40] + numeroSudoku[49] + numeroSudoku[58] + numeroSudoku[67] + numeroSudoku[76] == 45 )
  39.                    {
  40.                        if(numeroSudoku[5] + numeroSudoku[14] + numeroSudoku[23] + numeroSudoku[32] + numeroSudoku[41] + numeroSudoku[50] + numeroSudoku[59] + numeroSudoku[68] + numeroSudoku[77] == 45 )
  41.                        {
  42.                            if(numeroSudoku[6] + numeroSudoku[15] + numeroSudoku[24] + numeroSudoku[33] + numeroSudoku[42] + numeroSudoku[51] + numeroSudoku[60] + numeroSudoku[69] + numeroSudoku[78] == 45 )
  43.                            {
  44.                                if(numeroSudoku[7] + numeroSudoku[16] + numeroSudoku[25] + numeroSudoku[34] + numeroSudoku[43] + numeroSudoku[52] + numeroSudoku[61] + numeroSudoku[70] + numeroSudoku[79] == 45 )
  45.                                {
  46.                                    if(numeroSudoku[8] + numeroSudoku[17] + numeroSudoku[26] + numeroSudoku[35] + numeroSudoku[44] + numeroSudoku[53] + numeroSudoku[62] + numeroSudoku[71] + numeroSudoku[80] == 45 )
  47.                                    {
  48.                                        return true;
  49.                                    }
  50.                                }
  51.                            }
  52.                        }
  53.                    }
  54.                }
  55.            }
  56.        }
  57.    }
  58.    else return false;
  59. }
  60.  
  61. bool compruebaHorizontal()
  62. {
  63.    bool sudokuCorrecto = false;
  64.    if(numeroSudoku[0] + numeroSudoku[1] + numeroSudoku[2] + numeroSudoku[3] + numeroSudoku[4] + numeroSudoku[5] + numeroSudoku[6] + numeroSudoku[7] + numeroSudoku[8] == 45 )
  65.    {
  66.        if(numeroSudoku[9] + numeroSudoku[10] + numeroSudoku[11] + numeroSudoku[12] + numeroSudoku[13] + numeroSudoku[14] + numeroSudoku[15] + numeroSudoku[16] + numeroSudoku[17] == 45 )
  67.        {
  68.            if(numeroSudoku[18] + numeroSudoku[19] + numeroSudoku[20] + numeroSudoku[21] + numeroSudoku[22] + numeroSudoku[23] + numeroSudoku[24] + numeroSudoku[25] + numeroSudoku[26] == 45 )
  69.            {
  70.                if(numeroSudoku[27] + numeroSudoku[28] + numeroSudoku[29] + numeroSudoku[30] + numeroSudoku[31] + numeroSudoku[32] + numeroSudoku[33] + numeroSudoku[34] + numeroSudoku[35] == 45 )
  71.                {
  72.                    if(numeroSudoku[36] + numeroSudoku[37] + numeroSudoku[38] + numeroSudoku[39] + numeroSudoku[40] + numeroSudoku[41] + numeroSudoku[42] + numeroSudoku[43] + numeroSudoku[44] == 45 )
  73.                    {
  74.                        if(numeroSudoku[45] + numeroSudoku[46] + numeroSudoku[47] + numeroSudoku[48] + numeroSudoku[49] + numeroSudoku[50] + numeroSudoku[51] + numeroSudoku[52] + numeroSudoku[53] == 45 )
  75.                        {
  76.                            if(numeroSudoku[54] + numeroSudoku[55] + numeroSudoku[56] + numeroSudoku[57] + numeroSudoku[58] + numeroSudoku[59] + numeroSudoku[60] + numeroSudoku[61] + numeroSudoku[62] == 45 )
  77.                            {
  78.                                if(numeroSudoku[63] + numeroSudoku[64] + numeroSudoku[65] + numeroSudoku[66] + numeroSudoku[67] + numeroSudoku[68] + numeroSudoku[69] + numeroSudoku[70] + numeroSudoku[71] == 45 )
  79.                                {
  80.                                    if(numeroSudoku[72] + numeroSudoku[73] + numeroSudoku[74] + numeroSudoku[75] + numeroSudoku[76] + numeroSudoku[77] + numeroSudoku[78] + numeroSudoku[79] + numeroSudoku[80] == 45 )
  81.                                    {
  82.                                        return true;
  83.                                    }
  84.                                }
  85.                            }
  86.                        }
  87.                    }
  88.                }
  89.            }
  90.        }
  91.    }
  92.    else return false;
  93. }
  94.  
  95. bool compruebaCuadros()
  96. {
  97.    bool sudokuCorrecto = false;
  98.    if(numeroSudoku[0] + numeroSudoku[1] + numeroSudoku[2] + numeroSudoku[9] + numeroSudoku[10] + numeroSudoku[11] + numeroSudoku[18] + numeroSudoku[19] + numeroSudoku[20] == 45 )
  99.    {
  100.        if(numeroSudoku[3] + numeroSudoku[4] + numeroSudoku[5] + numeroSudoku[12] + numeroSudoku[13] + numeroSudoku[14] + numeroSudoku[21] + numeroSudoku[22] + numeroSudoku[23] == 45 )
  101.        {
  102.            if(numeroSudoku[6] + numeroSudoku[7] + numeroSudoku[8] + numeroSudoku[15] + numeroSudoku[16] + numeroSudoku[17] + numeroSudoku[24] + numeroSudoku[25] + numeroSudoku[26] == 45 )
  103.            {
  104.                if(numeroSudoku[27] + numeroSudoku[28] + numeroSudoku[29] + numeroSudoku[36] + numeroSudoku[37] + numeroSudoku[38] + numeroSudoku[45] + numeroSudoku[46] + numeroSudoku[47] == 45 )
  105.                {
  106.                    if(numeroSudoku[30] + numeroSudoku[31] + numeroSudoku[32] + numeroSudoku[39] + numeroSudoku[40] + numeroSudoku[41] + numeroSudoku[49] + numeroSudoku[50] + numeroSudoku[51] == 45 )
  107.                    {
  108.                        if(numeroSudoku[33] + numeroSudoku[34] + numeroSudoku[35] + numeroSudoku[42] + numeroSudoku[43] + numeroSudoku[44] + numeroSudoku[51] + numeroSudoku[52] + numeroSudoku[53] == 45 )
  109.                        {
  110.                            if(numeroSudoku[54] + numeroSudoku[55] + numeroSudoku[56] + numeroSudoku[63] + numeroSudoku[64] + numeroSudoku[65] + numeroSudoku[72] + numeroSudoku[73] + numeroSudoku[74] == 45 )
  111.                            {
  112.                                if(numeroSudoku[57] + numeroSudoku[58] + numeroSudoku[59] + numeroSudoku[66] + numeroSudoku[67] + numeroSudoku[68] + numeroSudoku[75] + numeroSudoku[76] + numeroSudoku[77] == 45 )
  113.                                {
  114.                                    if(numeroSudoku[60] + numeroSudoku[61] + numeroSudoku[62] + numeroSudoku[69] + numeroSudoku[70] + numeroSudoku[71] + numeroSudoku[78] + numeroSudoku[79] + numeroSudoku[80] == 45 )
  115.                                    {
  116.                                        return true;
  117.                                    }
  118.                                }
  119.                            }
  120.                        }
  121.                    }
  122.                }
  123.            }
  124.        }
  125.    }
  126.    else return false;
  127. }
  128.  

El código no está para nada optimizado (puede ocupar menos de la mitad de lineas usando arrays multidimensionales),lo he hecho rápido antes de ir a acostarme :). El usuario introduce los valores por lineas en un archivo de texto, de izquierda a derecha del sudoku es decir siguiendo esta imagen:

http://i.msdn.microsoft.com/dynimg/IC37479.gif

Una parte del archivo de texto quedaría así:

Código:
6
3
2
7
8
1
9
4
5
...

Precisamente con el sudoku de ese gif he hecho la prueba del programa y funciona



Cuando tenga tiempo lo optimizaré, de momento 35 puntos más, esto engancha que te cagas  :xD
32  Programación / Programación C/C++ / Re: [Solucionado] ¿Cambia el valor de una variable dentro una funcion? en: 1 Octubre 2012, 20:53 pm
Los punteros los tratan mas adelante en el libro que estoy leyendo, asi que voy a dejarlos para cuando toque, he compilado el codigo que has dejado y me da el sigueinte error:


Pero el ámbito o alcance de las variables ya se supone que lo tendrías que haber visto. He compilado los 3 códigos y no me da ningún error en ninguno de los 3 tio, mira a ver si lo has copiado bien :)
33  Programación / Programación C/C++ / Re: Proyecto C/C++ en: 1 Octubre 2012, 20:43 pm
Yo no tengo tiempo de conectarme al skype por culpa del tiempo que me roba la universidad, cuando necesitéis la implementación de la GUI me avisáis.
34  Programación / Programación C/C++ / Re: [Solucionado] ¿Cambia el valor de una variable dentro una funcion? en: 1 Octubre 2012, 20:33 pm
Eso es básico, alcance de las variables vamos. La variable a es declarada y definida en main() por lo que es considerada como variable local si la pasas como argumento a una función, por mucho que modifiques su valor no cambiará ya que la variable que pretendes "modificar" sigue siendo local a main a pesar de tener el mismo nombre que en la otra función. Si lo que quieres es modificarla pasa la variable por referencia, ahí ya hablamos de otra cosa o si lo prefieres puedes usar punteros o los 2.

Punteros y Referencias:

Código
  1. #include <stdio.h>
  2.  
  3. void modificar(int &a) {
  4. a *= 3;
  5. printf("\n\na = %d (desde la funcion, modificando el valor)", a);
  6. return ;
  7. }
  8.  
  9. int main() {
  10.  
  11. int *a = new int(2);
  12.  
  13. printf("\na = %d (desde main, antes de llamar a la funcion)", *a);
  14. modificar(*a);
  15. printf("\n\na = %d (desde main, despues de llamar a la funcion)", *a);
  16. getchar();
  17. }
  18.  
  19.  

Punteros:

Código
  1. #include <stdio.h>
  2.  
  3. void modificar(int *a) {
  4. *a *= 3;
  5. printf("\n\na = %d (desde la funcion, modificando el valor)", *a);
  6. return ;
  7. }
  8.  
  9. int main() {
  10.  
  11. int *a = new int(2);
  12. printf("\na = %d (desde main, antes de llamar a la funcion)", *a);
  13. modificar(a);
  14. printf("\n\na = %d (desde main, despues de llamar a la funcion)", *a);
  15. getchar();
  16. }
  17.  
  18.  

Referencia:

Código
  1. #include <stdio.h>
  2.  
  3. void modificar(int &a) {
  4. a *= 3;
  5. printf("\n\na = %d (desde la funcion, modificando el valor)", a);
  6. return ;
  7. }
  8.  
  9. int main() {
  10.  
  11. int a = 2;
  12.  
  13. printf("\na = %d (desde main, antes de llamar a la funcion)", a);
  14. modificar(a);
  15. printf("\n\na = %d (desde main, despues de llamar a la funcion)", a);
  16. getchar();
  17. }
  18.  
35  Programación / Programación C/C++ / Re: RETOS C++ en: 1 Octubre 2012, 18:20 pm
muy raro no creo que sea, al 100% de la gente que usa g++ seguro que le paso.

Tu con que compilas?

Codeblocks con MinGW
36  Programación / Programación C/C++ / Re: RETOS C++ en: 1 Octubre 2012, 17:56 pm
si no declaro
#include <string>

me da error de que no declare las variables

muy raro a mi no me pasa, pero bueno si quieres te escribo el código con string incluido xD
37  Programación / Programación C/C++ / Re: RETOS C++ en: 1 Octubre 2012, 16:47 pm
yo decia el include k sino da error
como minimo con el g++ en windows

Da error con que? No tengo que incluir ninguna librería como string si es a lo que te refieres :)
38  Programación / Programación C/C++ / Re: RETOS C++ en: 1 Octubre 2012, 16:43 pm
Código
  1. #include <iostream>
  2. int main(int argc,char* argv)
  3. {
  4.   ******* std::string palabra1,palabra2,palabra3,palabra4;*******
  5.    std::cin >> palabra1 >> palabra2 >> palabra3 >> palabra4;
  6.    if(palabra1 < palabra2 && palabra1 < palabra3 && palabra1 < palabra4){std::cout <<"La palabra mas pequenya es: " << palabra1 << std::endl;}
  7.    else{if(palabra2 < palabra1 && palabra2 < palabra3 && palabra2 < palabra4){std::cout <<"La palabra mas pequenya es: " << palabra2 << std::endl;}
  8.    else{if(palabra3 < palabra2 && palabra3 < palabra1 && palabra3 < palabra4){std::cout <<"La palabra mas pequenya es: " << palabra3 << std::endl;}
  9.    else{if(palabra4 < palabra2 && palabra4 < palabra3 && palabra4 < palabra1){std::cout <<"La palabra mas pequenya es: " << palabra4 << std::endl;}}}}
  10.    if(palabra1 == palabra2 && palabra1 == palabra3 && palabra1 == palabra4){std::cout <<"Todas las palabras son iguales" << std::endl;}
  11.    return 0;
  12. }

Yo los veo declarados xD. Pero bueno, los retos los llevas tú y tú mandas :)
39  Programación / Programación C/C++ / Re: RETOS C++ en: 1 Octubre 2012, 16:27 pm
ahora miro el code peor no seria mejor esto;

Código:
#include <iostream>
#include <algorithm>
using namespace std;

int main () {
int a,b,c,d;
cin >> a >> b >> c >> d;

if (max(a,b)>max(c,d)) {
  cout << max(a,b) << endl;
  } else {
    cout << max(c,d) << endl;
}
}

usando max con un solo if basta para comparar los 4 numeros, seguramente hay otras formas pero esta es una.


Si va por mi último post, el reto no es el de los números si no el de los strings y la función max de algorithm no funciona igual. Además, no veo ninguna dificultad en usar la función para que haga el trabajo por ti, es más "complicado" implementar tú la función que lleva a cabo así que no sé porque se tienen que dar más puntos por una simple llamada a función xD
40  Programación / Programación C/C++ / Re: RETOS C++ en: 1 Octubre 2012, 15:47 pm
RETO 4

Código
  1. #include <iostream>
  2. int main(int argc,char* argv)
  3. {
  4.    std::string palabra1,palabra2,palabra3,palabra4;
  5.    std::cin >> palabra1 >> palabra2 >> palabra3 >> palabra4;
  6.    if(palabra1 < palabra2 && palabra1 < palabra3 && palabra1 < palabra4){std::cout <<"La palabra mas pequenya es: " << palabra1 << std::endl;}
  7.    else{if(palabra2 < palabra1 && palabra2 < palabra3 && palabra2 < palabra4){std::cout <<"La palabra mas pequenya es: " << palabra2 << std::endl;}
  8.    else{if(palabra3 < palabra2 && palabra3 < palabra1 && palabra3 < palabra4){std::cout <<"La palabra mas pequenya es: " << palabra3 << std::endl;}
  9.    else{if(palabra4 < palabra2 && palabra4 < palabra3 && palabra4 < palabra1){std::cout <<"La palabra mas pequenya es: " << palabra4 << std::endl;}}}}
  10.    if(palabra1 == palabra2 && palabra1 == palabra3 && palabra1 == palabra4){std::cout <<"Todas las palabras son iguales" << std::endl;}
  11.    return 0;
  12. }
  13.  
Páginas: 1 2 3 [4] 5 6 7 8 9 10 11 12 13 14 15 16 17 18
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines