Java implementation of the Solving Maze algorithm presented by Computerphile.
You can check out the releases page to download binaries. Java 17 needs to be installed.
NOTE: If you download the os/platform specific binary (*-<platform>.zip
) you do not need Java installed on your system.
From the bin folder, you can run:
- Linux & Mac
$./maze-solver
- Windows
bin>.\maze-solver
The main idea is that there is maze represented by a binary image. The image contains white pixels which represent free tiles and black pixels which represent impassable / blocked tiles. There is a single free tile on the top row, which represents the starting point. There is also a single free tile on the last row, which represents the destination / maze exit. The goal is to find the shortest path from the starting point to the maze exit.
This project is inspired by the maze solving algorithm from Computerphile. There is a dedicated repository for this. The original implementation is in Python. I have also used the same mazes.
The currently supported algorithms are:
- Dijkstra (default)
- A*
- Breadth-First-Search (BFS)
- Depth-First-Search (DFS)
The algorithm / strategy can be specified when running the application:
$./maze-solver -s ${strategy}
Where strategy can be one of the following:
- dijkstra
- a-star
- bfs
- dfs
The only dependency is JUnit (Eclipse Public License).
NOTE: Be careful when using bigger mazes as it will use a lot of CPU and RAM.
A file chooser will be launched upon executing the jar file, either directly or via command line, prompting you to select one of the mazes, unless the maze path is already specified using either the -mp or --maze-path options.
Upon selecting the maze, the shortest path will be searched and after that a file will be written in the same directory as the original file with the name solved_<original-file-name>.
At the moment only PNG format is supported.
Some sample data:
- tiny.png
- small.png
- normal.png
Here is an example of a bigger one (4k x 4k pixels):
And an even bigger one (10k x 10k):
You can find multiple solved mazes in the docs directory.