Skip to content

Latest commit

 

History

History
88 lines (63 loc) · 2.16 KB

24.md

File metadata and controls

88 lines (63 loc) · 2.16 KB

⬅️ Regresar

24 - El último reto es un laberinto

Instrucciones

¡Ha llegado el día! Hoy vamos a repartir los regalos… pero los almacenes son un labertinto y los elfos están perdidos.

Indielfo Jones quiere escribir un programa que al recibir una matriz, sepa si puede salir o no del laberinto rápidamente desde su entrada a la salida.

Los laberintos tienen las siguientes posiciones:

  • W: Es una pared, no se puede pasar por ahí.
  • S: Punto de entrada al almacén.
  • E: Punto de salida del almacén.
  • : Los espacios en blanco es por donde se puede pasar.

Los movimientos válidos son de una posición hacia arriba, abajo, izquierda o derecha. No se puede mover en diagonal.

canExit([
  [' ', ' ', 'W', ' ', 'S'],
  [' ', ' ', ' ', ' ', ' '],
  [' ', ' ', ' ', 'W', ' '],
  ['W', 'W', ' ', 'W', 'W'],
  [' ', ' ', ' ', ' ', 'E']
]) // -> true

// Se puede salir porque empezamos en [0, 4]
// y hay un camino hasta la salida que es [4, 4]

canExit([
  [' ', ' ', 'W', 'W', 'S'],
  [' ', ' ', ' ', 'W', ' '],
  [' ', ' ', ' ', 'W', ' '],
  ['W', 'W', ' ', 'W', 'W'],
  [' ', ' ', ' ', ' ', 'E']
]) // -> false

// No hay manera de llegar de [0, 4] a [4, 4]

Recuerda que:

  • Sólo tienes que devolver si se puede salir del laberinto con un booleano.
  • Las paredes W no se pueden saltar.
  • No se pueden salir de los límites de la matriz, siempre hay que seguir un camino interno.


Solución

function canExit(maze) {
	let memory = []
	function findEnd (position) {
		memory.push(position.toString())

		const positions = [[position[0] - 1, position[1]],
		[position[0] + 1, position[1]],
		[position[0], position[1] + 1],
		[position[0], position[1] - 1]]

		for (const pos of positions) {
			const content = maze[pos[0]] ? maze[pos[0]][pos[1]] : null
			if (content === "S" || content === " "
				&& !memory.includes(pos.toString())
				&& findEnd(pos) === true) return true
		}
	}
	let k = maze.findIndex(item => item.includes("E"))
	return findEnd([k, maze[k].indexOf("E")]) || false
}

Puntaje: 150


⬅️ Regresar