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

 

 


Tema destacado: Security Series.XSS. [Cross Site Scripting]


  Mostrar Mensajes
Páginas: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 [16] 17 18 19 20 21 22 23 24 25 26 27
151  Comunicaciones / Redes / Re: No puedo acceder a las paginas web en: 30 Marzo 2014, 06:37 am
Aqui esta mejor




Acabo de hacer ping por lo menos a facebook y alli me dice "Tiempo de espera agotado para esta solicitud, 4 paquetes perdidos"
152  Comunicaciones / Redes / Re: No puedo acceder a las paginas web en: 30 Marzo 2014, 06:31 am
4 paquetes enviados, 4 paquetes recibidos

Tiempo aproximado de ida y vuelta en milisegundos:

minimo 231, maximo 254, media 244
153  Comunicaciones / Redes / Re: No puedo acceder a las paginas web en: 30 Marzo 2014, 06:18 am
Bueno primera vez que me sucede esto, y agradeceria que me explicaran al menos, entre en las conexiones de red, en propiedades protocolo TCP/IPv4

servidor DNS preferido      8.8.8.8
servidor DNS alternativo    8.8.4.4

Y aun asi no me puedo conectar, sigue el problema =/
154  Comunicaciones / Redes / No puedo acceder a las paginas web en: 30 Marzo 2014, 06:04 am
Hola que tal, hoy se me fue la luz y cuando trate de entrar de nuevo a navegar no podia acceder a la mayoria de las paginas web, en estos momentos uso Tor el cual es el unico que me permite poder acceder a todas las paginas ,ni chrome, ni firefox, ni internet explorer me permiten acceder a ellas, no se si sea que el router se desconfiguro, aunque ya lo configure como de fabrica y en realidad no se a que se deba esto =/ agradeceria mucho que me ayuden.
155  Programación / Programación C/C++ / Re: Ayuda optimizacion busqueda de salida en laberinto en: 29 Marzo 2014, 19:18 pm
Gracias amchacon, ya vi como poder entrarle al ejercicio
156  Programación / Programación C/C++ / Re: Ayuda optimizacion busqueda de salida en laberinto en: 28 Marzo 2014, 22:20 pm
Eso depende del escenario, para un juego es otra cosa, son distintas reglas
157  Programación / Programación C/C++ / Re: Ayuda optimizacion busqueda de salida en laberinto en: 28 Marzo 2014, 20:24 pm
Si pero es que un algoritmo que busque aleatoriamente podria tardar una eternidad en recorrer todo el laberinto, redundando en caminos que ya hubiese pasado anteriormente
158  Programación / Programación C/C++ / Re: Ayuda optimizacion busqueda de salida en laberinto en: 28 Marzo 2014, 20:01 pm
Viendo ejemplos de códigos recursivos logre modificar mi programa ( hice que la función retornara valores, y modifique los if ), ahora el programa si busca caminos alternativos, pero aun asi existen caminos que no recorre, en el caso de mi laberinto, si a la posicion que deberia ser la salida lo hago un obstaculo, al programa le quedarían 2 caminos por verificar

Coloco todo el codigo de nuevo porque hice algun cambio en main

Código
  1. #include <stdio.h>
  2. #include <stdlib.h>     // Para usar funcion de limpiar pantalla
  3. #include <windows.h>    // Para usar funcion de hacer pausa
  4. #define TAM_FIL 12
  5. #define TAM_COL 12
  6.  
  7. typedef struct
  8. {
  9.    int estaEnFinal; //------------------- Para saber si llego al final el objeto
  10.    char simbolo;
  11.    int pos_x; //------------------------- Coordenada del objeto en X
  12.    int pos_y; //------------------------- Coordenada del objeto en Y
  13. }Objeto;
  14.  
  15. typedef struct
  16. {
  17.    // ----------------------------------- Simplemente para saber las coordenadas de los puntos X e Y de inicio y fin del laberinto ------------------------------------
  18.  
  19.    int ini_fil;
  20.    int ini_col;
  21.    int fin_fil;
  22.    int fin_col;
  23. }InformacionMapa;
  24.  
  25. void mostrarEstadoMapa( char laberinto[][TAM_COL] );
  26. int recorrerLaberinto( char laberinto[][TAM_COL], InformacionMapa *punto, Objeto obj );
  27.  
  28. int main( int argc, char* args[] )
  29. {
  30.  
  31.  
  32.    InformacionMapa mapa;
  33.    mapa.ini_fil = 2;
  34.    mapa.ini_col = 0;
  35.    mapa.fin_fil = 4;
  36.    mapa.fin_col = 11;
  37.  
  38.    Objeto obj;
  39.    obj.simbolo = 'X';
  40.    obj.estaEnFinal = 0;
  41.    obj.pos_x = 2;
  42.    obj.pos_y = 0;
  43.  
  44.    char laberinto[TAM_FIL][TAM_COL] = { '#', '#', '#', '#', '#', '#', '#', '#', '#', '#', '#', '#',
  45.                                         '#', ' ', ' ', ' ', '#', ' ', ' ', ' ', ' ', ' ', ' ', '#',
  46.                                         ' ', ' ', '#', ' ', '#', ' ', '#', '#', '#', '#', ' ', '#',
  47.                                         '#', '#', '#', ' ', '#', ' ', ' ', ' ', ' ', '#', ' ', '#',
  48.                                         '#', ' ', ' ', ' ', ' ', '#', '#', '#', ' ', ' ', ' ', ' ',
  49.                                         '#', '#', '#', '#', ' ', '#', ' ', '#', ' ', '#', ' ', '#',
  50.                                         '#', ' ', ' ', '#', ' ', '#', ' ', '#', ' ', '#', ' ', '#',
  51.                                         '#', '#', ' ', '#', ' ', '#', ' ', '#', ' ', '#', ' ', '#',
  52.                                         '#', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', '#', ' ', '#',
  53.                                         '#', '#', '#', '#', '#', '#', ' ', '#', '#', '#', ' ', '#',
  54.                                         '#', ' ', ' ', ' ', ' ', ' ', ' ', '#', ' ', ' ', ' ', '#',
  55.                                         '#', '#', '#', '#', '#', '#', '#', '#', '#', '#', '#', '#'
  56.                                       };
  57.  
  58.    if( recorrerLaberinto( laberinto, &mapa, obj ) == 1 )
  59.        printf("\n\n\nFinal del laberinto encontrado");
  60.    else
  61.        printf("\n\n\nNo hay salida en este laberinto.");
  62.  
  63.    getchar();
  64. return 0;
  65. }
  66.  
  67. void mostrarEstadoMapa( char laberinto[][TAM_COL] )
  68. {
  69.    int cont_fil, cont_col;
  70.  
  71.    system("cls");
  72.    for( cont_fil = 0; cont_fil < TAM_FIL; cont_fil++ )
  73.    {
  74.        for( cont_col = 0; cont_col < TAM_COL; cont_col++ )
  75.        {
  76.            printf("%c", laberinto[cont_fil][cont_col]);
  77.            printf("  ");
  78.        }
  79.  
  80.        printf("\n\n");
  81.    }
  82.    Sleep(200);
  83. }
  84.  
  85. int recorrerLaberinto( char laberinto[][TAM_COL], InformacionMapa *mapa, Objeto obj )
  86. {
  87.  
  88.    if( obj.pos_x == mapa->fin_fil && obj.pos_y == mapa->fin_col )
  89.    {
  90.        obj.estaEnFinal++;
  91.        return 1;
  92.    }
  93.  
  94.    laberinto[obj.pos_x][obj.pos_y] = obj.simbolo;
  95.  
  96.    mostrarEstadoMapa( laberinto );
  97.  
  98.    if( laberinto[obj.pos_x][obj.pos_y + 1] == ' ' && obj.pos_y + 1 < TAM_COL )
  99.    {
  100.        obj.pos_y++;
  101.        if( recorrerLaberinto( laberinto, mapa, obj ) == 1 )
  102.            return 1;
  103.    }
  104.  
  105.    if( laberinto[obj.pos_x + 1][obj.pos_y] == ' ' && obj.pos_x + 1 < TAM_FIL )
  106.    {
  107.        obj.pos_x++;
  108.        if( recorrerLaberinto( laberinto, mapa, obj ) == 1 )
  109.            return 1;
  110.    }
  111.  
  112.    if( laberinto[obj.pos_x - 1][obj.pos_y] == ' ' && obj.pos_x - 1 >= 0 )
  113.    {
  114.        obj.pos_x--;
  115.        if( recorrerLaberinto( laberinto, mapa, obj ) == 1 )
  116.            return 1;
  117.    }
  118.  
  119.    if( laberinto[obj.pos_x][obj.pos_y - 1] == ' ' && obj.pos_y - 1 >= 0 )
  120.    {
  121.        obj.pos_y--;
  122.        if( recorrerLaberinto( laberinto, mapa, obj ) == 1 )
  123.            return 1;
  124.    }
  125.  
  126.    return 0;
  127. }
  128.  
  129.  
159  Programación / Programación C/C++ / Re: Ayuda optimizacion busqueda de salida en laberinto en: 28 Marzo 2014, 14:36 pm
El using namespace std; si fue un descuido se me habia olvidado borrar esa linea, solo que cuando intente modificar el post cuando le daba previsualizar me mostraba algunos caracteres raros y lo deje asi y bueno estaba intentando resolverlo con recursividad, la linea

Código
  1. if( laberinto[obj->pos_x][obj->pos_y + 1] != '#' && laberinto[obj->pos_x][obj->pos_y + 1] != obj->simbolo )

Simplemente la use para saber si cuando el objeto se mueva a la posicion siguiente no haya obstaculo '#' o no esté ya su simbolo (indicando que ya paso por alli), pero como dije, los problemas de recursividad me cuestan pensarlos.
160  Programación / Programación C/C++ / Ayuda optimizacion busqueda de salida en laberinto en: 28 Marzo 2014, 02:40 am
Hola, aqui les traigo un problema que estoy haciendo sobre, dado un laberinto de 12 x 12 usar la regla de la mano derecha para conseguir la salida del laberinto e indicar si hay salida o no, como tal el programa corre y si encuentra la salida, pero no se si lo esta haciendo de la mejor manera, he aqui el codigo:

Código
  1. #include <stdio.h>
  2. #include <stdlib.h>     // Para usar funcion de limpiar pantalla
  3. #include <windows.h>    // Para usar funcion de hacer pausa
  4. #define TAM_FIL 12
  5. #define TAM_COL 12
  6.  
  7. using namespace std;
  8.  
  9. typedef struct
  10. {
  11.    int estaEnInicio, estaEnFinal; //----- Para saber cuantas veces nuestro objeto ha estado en el inicio y si esta en el final
  12.    char simbolo;
  13.    int pos_x; //------------------------- Coordenada del objeto en X
  14.    int pos_y; //------------------------- Coordenada del objeto en Y
  15. }Objeto;
  16.  
  17. typedef struct
  18. {
  19.    // ----------------------------------- Simplemente para saber las coordenadas de los puntos X e Y de inicio y fin del laberinto ------------------------------------
  20.  
  21.    int ini_fil;
  22.    int ini_col;
  23.    int fin_fil;
  24.    int fin_col;
  25. }InformacionMapa;
  26.  
  27. void mostrarEstadoMapa( char laberinto[][TAM_COL] );
  28. void recorrerLaberinto( char laberinto[][TAM_COL], InformacionMapa *punto, Objeto *obj );
  29.  
  30. int main( int argc, char* args[] )
  31. {
  32.  
  33.    int cont_fil, cont_col;
  34.  
  35.    InformacionMapa mapa;
  36.    mapa.ini_fil = 2;
  37.    mapa.ini_col = 0;
  38.    mapa.fin_fil = 4;
  39.    mapa.fin_col = 11;
  40.  
  41.    Objeto obj;
  42.    obj.simbolo = 'X';
  43.    obj.estaEnInicio = 0;
  44.    obj.estaEnFinal = 0;
  45.    obj.pos_x = 2;
  46.    obj.pos_y = 0;
  47.  
  48.    char laberinto[TAM_FIL][TAM_COL] = { '#', '#', '#', '#', '#', '#', '#', '#', '#', '#', '#', '#',
  49.                                         '#', ' ', ' ', ' ', '#', ' ', ' ', ' ', ' ', ' ', ' ', '#',
  50.                                         ' ', ' ', '#', ' ', '#', ' ', '#', '#', '#', '#', ' ', '#',
  51.                                         '#', '#', '#', ' ', '#', ' ', ' ', ' ', ' ', '#', ' ', '#',
  52.                                         '#', ' ', ' ', ' ', ' ', '#', '#', '#', ' ', ' ', ' ', ' ',
  53.                                         '#', '#', '#', '#', ' ', '#', ' ', '#', ' ', '#', ' ', '#',
  54.                                         '#', ' ', ' ', '#', ' ', '#', ' ', '#', ' ', '#', ' ', '#',
  55.                                         '#', '#', ' ', '#', ' ', '#', ' ', '#', ' ', '#', ' ', '#',
  56.                                         '#', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', '#', ' ', '#',
  57.                                         '#', '#', '#', '#', '#', '#', ' ', '#', '#', '#', ' ', '#',
  58.                                         '#', ' ', ' ', ' ', ' ', ' ', ' ', '#', ' ', ' ', ' ', '#',
  59.                                         '#', '#', '#', '#', '#', '#', '#', '#', '#', '#', '#', '#'
  60.                                       };
  61.  
  62.    recorrerLaberinto( laberinto, &mapa, &obj );
  63.  
  64.    getchar();
  65. return 0;
  66. }
  67.  
  68. void mostrarEstadoMapa( char laberinto[][TAM_COL] )
  69. {
  70.    int cont_fil, cont_col;
  71.  
  72.    system("cls");
  73.    for( cont_fil = 0; cont_fil < TAM_FIL; cont_fil++ )
  74.    {
  75.        for( cont_col = 0; cont_col < TAM_COL; cont_col++ )
  76.        {
  77.            printf("%c", laberinto[cont_fil][cont_col]);
  78.            printf("  ");
  79.        }
  80.  
  81.        printf("\n\n");
  82.    }
  83.    Sleep(500);
  84. }
  85.  
  86. void recorrerLaberinto( char laberinto[][TAM_COL], InformacionMapa *mapa, Objeto *obj )
  87. {
  88.  
  89.    if( obj->pos_x == mapa->ini_fil && obj->pos_y == mapa->ini_col )
  90.        obj->estaEnInicio++;
  91.    else if( obj->pos_x == mapa->fin_fil && obj->pos_y == mapa->fin_col )
  92.        obj->estaEnFinal++;
  93.  
  94.    while( laberinto[4][11] != obj->simbolo && obj->estaEnInicio == 1 && !obj->estaEnFinal )
  95.    {
  96.        laberinto[obj->pos_x][obj->pos_y] = obj->simbolo;
  97.  
  98.        mostrarEstadoMapa( laberinto );
  99.  
  100.        if( laberinto[obj->pos_x][obj->pos_y + 1] != '#' && laberinto[obj->pos_x][obj->pos_y + 1] != obj->simbolo )
  101.        {
  102.            obj->pos_y++;
  103.            recorrerLaberinto( laberinto, mapa, obj );
  104.        }
  105.        else if( laberinto[obj->pos_x + 1][obj->pos_y] != '#' && laberinto[obj->pos_x + 1][obj->pos_y] != obj->simbolo )
  106.        {
  107.            obj->pos_x++;
  108.            recorrerLaberinto( laberinto, mapa, obj );
  109.        }
  110.        else if( laberinto[obj->pos_x - 1][obj->pos_y] != '#' && laberinto[obj->pos_x - 1][obj->pos_y] != obj->simbolo )
  111.        {
  112.            obj->pos_x--;
  113.            recorrerLaberinto( laberinto, mapa, obj );
  114.        }
  115.        else if( laberinto[obj->pos_x][obj->pos_y - 1] != '#' && laberinto[obj->pos_x][obj->pos_y - 1] != obj->simbolo )
  116.        {
  117.            obj->pos_y--;
  118.            recorrerLaberinto( laberinto, mapa, obj );
  119.        }
  120.        else if( laberinto[obj->pos_x][obj->pos_y - 1] != '#' )
  121.        {
  122.            obj->pos_y--;
  123.            recorrerLaberinto( laberinto, mapa, obj );
  124.        }
  125.        else if( laberinto[obj->pos_x - 1][obj->pos_y] != '#' )
  126.        {
  127.            obj->pos_x--;
  128.            recorrerLaberinto( laberinto, mapa, obj );
  129.        }
  130.        else if( laberinto[obj->pos_x + 1][obj->pos_y] != '#' )
  131.        {
  132.            obj->pos_x++;
  133.            recorrerLaberinto( laberinto, mapa, obj );
  134.        }
  135.        else if( laberinto[obj->pos_x][obj->pos_y + 1] != '#' )
  136.        {
  137.            obj->pos_y++;
  138.            recorrerLaberinto( laberinto, mapa, obj );
  139.        }
  140.  
  141.    }
  142.  
  143.    if( obj->estaEnInicio > 1 )
  144.        printf("\n\n\nNo hay salida en este laberinto.");
  145.    if( obj->estaEnFinal )
  146.        printf("\n\n\nFinal del laberinto encontrado");
  147. }
  148.  

Disculpen el exceso de if-else xD, debo mejorar esa parte.

Nota: Aun no lo he probado con un laberinto distinto con punto de partida y fin distintos.



He probado quitandole la salida y alli si que no hace la busqueda por todas las posibles rutas del laberinto, aunque se que esto seria un problema de backtracking, yo no soy muy experto cuando se trata de recursividad jeje
Páginas: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 [16] 17 18 19 20 21 22 23 24 25 26 27
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines