Created
August 31, 2018 12:43
cassidoo challenge 27-08-2018
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/* | |
Given a a 2D matrix that represents a maze (with 1s as walls and 0s as path). | |
Find a path from one corner to another, backtracking should be allowed. | |
Return an array of steps taken in order. | |
*/ | |
function included(lista, elem) { | |
var res=false; | |
var i=0; | |
var stringElem=JSON.stringify(elem); | |
while ((i<lista.length) && (!res)) { | |
res = JSON.stringify(lista[i++]) === stringElem; | |
} | |
return (res); | |
} | |
function way(maze, partialRes, index) { | |
// Precondition: maze not empty. | |
// Index represents the starting position | |
// It will find the way out, if there is one, from anywhere in the maze to | |
// the bottom right corner. | |
// This is a recursive function. | |
var dims = {x: maze.length, y: maze[0].length}; | |
if ((index.x<0) || (index.x>=dims.x) || (index.y<0) || (index.y>=dims.y)) { | |
// out of bounds | |
console.log("Out of bounds"); | |
console.log(index); | |
return({isViable: false , path:[]}); | |
} | |
else if (maze[index.x][index.y]) { // the current position is a wall, cannot go there | |
console.log("I hit a wall."); | |
console.log(index); | |
return({isViable: false, path:[]}); | |
} | |
else if ((index.x===dims.x-1) && (index.y===dims.y-1)) { // end of the maze! | |
console.log("¡Fin del laberinto! Yisss!"); | |
console.log(index); | |
return({isViable:true,path: partialRes.push(index)}); | |
} | |
else if (included(partialRes,index)) { // already visited | |
console.log("Casilla ya visitada."); | |
console.log(index); | |
return({isViable: false, path:[]}); | |
} | |
else { // recursive calls | |
partialRes.push(index); | |
if ((index.x-1>=0) && way(maze, partialRes, {x:index.x-1, y: index.y}).isViable) { | |
console.log("Viable x-1"); | |
console.log(index); | |
return({isViable: true, path: partialRes}); | |
} | |
else if ((index.x+1<dims.x) && way(maze, partialRes, {x:index.x+1, y: index.y}).isViable) { | |
console.log("Viable x+1"); | |
console.log(index); | |
return({isViable: true, path: partialRes}); | |
} | |
else if ((index.y-1>=0) && way(maze, partialRes, {x: index.x, y: index.y-1}).isViable){ | |
console.log("Viable y-1"); | |
console.log(index); | |
return({isViable: true, path: partialRes}); | |
} | |
else if ((index.y+1<dims.y) && way(maze, partialRes, {x: index.x, y: index.y+1}).isViable) { | |
console.log("Viable y+1"); | |
console.log(index); | |
return({isViable: true, path: partialRes}); | |
} | |
else { | |
console.log("No llego a nada: ni arriba, ni abajo, ni izquierda, ni derecha."); | |
console.log(index); | |
partialRes.pop(); | |
return({isViable: false, partialRes}); | |
} | |
} | |
} // function | |
var matriz = [[0,0,1],[1,0,1],[0,0,0]]; // good maze | |
if (typeof matriz !== 'undefined' && matriz.length > 0){ | |
var resultado=way(matriz,[],{x:0,y:0}); | |
console.log(resultado); // good maze | |
} | |
console.log("\n====================\n"); | |
var matriz2 = [[0,0,1],[1,0,1],[0,0,1]]; // maze with no solution | |
if (typeof matriz2 !== 'undefined' && matriz2.length > 0){ | |
var resultado=way(matriz2,[],{x:0,y:0}); | |
console.log(resultado); // maze with no solution | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment