ClubEnsayos.com - Ensayos de Calidad, Tareas y Monografias
Buscar

EL SALTO DE CABALLO


Enviado por   •  28 de Marzo de 2019  •  Apuntes  •  528 Palabras (3 Páginas)  •  107 Visitas

Página 1 de 3

EL SALTO DE CABALLO

El objetivo es encontrar una manera de recorrer todo el tablero partiendo de una casilla determinada, de tal forma que el caballo pase una sola vez por cada casilla. Una variante es obligar al caballo a volver a la posición de partida en el último movimiento.

Por último, se estudiará como encontrar todas las soluciones posibles partiendo de una misma casilla.

Para resolver el problema hay que realizar todos los movimientos posibles hasta que ya no se pueda avanzar, en cuyo caso hay que dar marcha atrás, o bien hasta que se cubra el tablero. Además, es necesario determinar la organización de los datos para implementar el algoritmo.

El tablero, del tamaño que sea, se representará mediante un array bidimensional de números enteros.[pic 1]

[pic 2][pic 3]

[pic 4]

        

A continuación, se expone un código completo en C, que recubre un tablero cuadrado de lado N partiendo de la posición (0,0).

#include

#define N 5

#define ncuad N*N

void mover(int tablero[][N], int i, int pos_x, int pos_y, int *q);

const int ejex[8] = { -1,-2,-2,-1, 1, 2, 2, 1 },

          ejey[8] = { -2,-1, 1, 2, 2, 1,-1,-2 };

int main(void)

{

  int tablero[N][N]; /* tablero del caballo. */

  int i,j,q;

   /* inicializa el tablero a cero */

  for (i = 0; i < N; i++)

   for (j = 0; j < N; j++)

    tablero[i][j] = 0;

   /* pone el primer movimiento */

  tablero[0][0] = 1;

  mover(tablero,2,0,0,&q);

  if (q) { /* hay solucion: la muestra. */

    for (i = 0; i < N; i++) {

      for (j = 0; j < N; j++)

        printf("%3d ", tablero[i][j]);

      putchar('\n');

    }

  }

  else

    printf("\nNo existe solucion\n");

  return 0;

}

void mover(int tablero[][N],int i, int pos_x, int pos_y, int *q)

{

  int k, u, v;

  k = 0;

  *q = 0;

  do {

    u = pos_x + ejex[k]; v = pos_y + ejey[k]; /* seleccionar candidato */

    if (u >= 0 && u < N && v >= 0 && v < N) { /* esta dentro de los limites? */

      if (tablero[u][v] == 0) {  /* es valido? */

        tablero[u][v] = i;  /* anota el candidato */

        if (i < ncuad) {  /* llega al final del recorrido? */

          mover(tablero,i+1,u,v,q);

          if (!*q) tablero[u][v] = 0; /* borra el candidato */

        }

        else *q = 1; /* hay solucion */

      }

    }

    k++;

...

Descargar como (para miembros actualizados)  txt (2.5 Kb)   pdf (105.1 Kb)   docx (72.9 Kb)  
Leer 2 páginas más »
Disponible sólo en Clubensayos.com