Maze Generation and Solving GitHub

WARNING: Videos contain flashing

Maze Creation

Dimensions of the mazes were determined by fibonacci numbers. Maze 0 was the 0th fibonacci number (1) by the 1st fibonacci number (1), maze 1 being the 1st fibonacci number by the 2nd (1 by 2), maze 2 being the 2nd by the 3rd (2 by 3) and so on. Mazes were initially a grid, as shown below.

Mazes were not allowed to have cycles, meaning there could only be one path between any two points within the maze. To convert the grids into actual mazes, either Prim's algorithm or an iterative implementation of randomized depth-first search were used.

Below is a video demonstration of Prim's Algorithm for generating mazes implemented in JAVA. The blue cells are cells currently in the list of possible cells to look at and the pink cell is the one currently being looked at.

Because the fibonacci sequence exhibits exponential growth, the largest maze my computer could generate was maze 21, which is 17711 cells by 28657 cells.

Maze Solving

Once the mazes were generated they were solved using recursive backtracking. Because these mazes grow to massive sizes, the recursive backtracking algorithm implemented utilized a stack data structure instead of recursion to avoid reaching the max recursive depth.

Below is a video demonstration of the maze generated in the previous video being solved using Recursive Backtracking. The grey cells are visited cells that resulted in a dead end, while the pink cells show the current solution's path.

Live Demo

I implemented my JAVA code in JavaScript (with some performance improvements), so you can actually generate mazes here! It's a pretty neat tool that could definitely use some work, but it's what I know how to do at the moment. The magnifying glasses with the + or - increase/decrease the size of the display, while the bar beneath the maze determines what number maze you'd like to generate. Selecting "solve" solves the current maze, and selecting "generate" builds a maze of the specified number. I set the max to 13, but I don't recommend it.