Rated as "One of the best I've seen" by Professor
- Authors: Zifan Si
Algorithms, 4th Edition https://algs4.cs.princeton.edu/44sp/AcyclicSP.java.html
This program explores a maze, finding a path from an entry point to an exit one.
- The maze is stored in a text file, with
#
representing walls and␣
(empty space) representing passages. - You’ll find examples of such mazes in the
examples
directory.- You can also use the Maze Generator to generate others.
- The Maze is surrounded by walls on its four borders, except for its entry/exit points.
- Entry and exit points are always located on the East and West border.
- The maze is not directed. As such, exit and entry can be interchanged.
- At the beginning of the exploration, we're located on the entry tile, facing the opposite side (e.g., if entering by the eastern entry, you're facing West).
- The program generates a sequence of instructions to reach the opposite exit (i.e., a "path"):
F
means 'move forward' according to your current directionR
means 'turn right' (does not move, just change direction), andL
means ‘turn left’.
- A canonical path contains only
F
,R
andL
symbols - A factorized path squashes together similar instructions (i.e.,
FFF
=3F
,LL
=2L
). - Spaces are ignored in the instruction sequence (only for readability:
FFLFF
=FF L FF
) - The program takes as input a maze and print the path on the standard output.
- For this assignment, the path does not have to be the shortest one.
- The program can take a path as input and verify if it's a legit one.
To build the program, simply package it with Maven:
mosser@azrael A1-Template % mvn -q clean package
The starter code assumes the maze file name is the first argument.
mosser@azrael A1-Template % java -jar target/mazerunner.jar ./examples/small.maz.txt
** Starting Maze Runner
**** Reading the maze from file ./examples/small.maz.txt
WALL WALL WALL WALL WALL WALL WALL WALL WALL WALL WALL
WALL PASS PASS PASS PASS PASS PASS PASS PASS PASS WALL
WALL WALL WALL PASS WALL WALL WALL PASS WALL WALL WALL
WALL PASS PASS PASS PASS PASS WALL PASS PASS PASS WALL
WALL PASS WALL PASS WALL WALL WALL WALL WALL PASS WALL
WALL PASS WALL PASS PASS PASS PASS PASS WALL PASS PASS
WALL WALL WALL PASS WALL PASS WALL WALL WALL WALL WALL
WALL PASS PASS PASS WALL PASS PASS PASS PASS PASS WALL
PASS PASS WALL PASS WALL PASS WALL WALL WALL PASS WALL
WALL PASS WALL PASS WALL PASS WALL PASS PASS PASS WALL
WALL WALL WALL WALL WALL WALL WALL WALL WALL WALL WALL
**** Computing path
PATH NOT COMPUTED
** End of MazeRunner
When called on a non-existing file. it prints an error message
mosser@azrael A1-Template % java -jar target/mazerunner.jar ./examples/small.maz.txtd
** Starting Maze Runner
**** Reading the maze from file ./examples/small.maz.txtd
/!\ An error has occured /!\
**** Computing path
PATH NOT COMPUTED
** End of MazeRunner
The delivered program at the end of this assignment should use the following flags:
-i MAZE_FILE
: specifies the filename to be used;-p PATH_SEQUENCE
: activates the path verification mode to validate that PATH_SEQUENCE is correct for the maze
If you are also delivering the bonus, your program will react to a third flag:
-method {tremaux, righthand}
: specifies which path computation method to use. (default is right hand)
When no logs are activated, the programs only print the computed path on the standard output.
mosser@azrael A1-Template % java -jar target/mazerunner.jar -i ./examples/straight.maz.txt
4F
mosser@azrael A1-Template %
If a given path is correct, the program prints the message correct path
on the standard output.
mosser@azrael A1-Template % java -jar target/mazerunner.jar -i ./examples/straight.maz.txt -p 4F
correct path
mosser@azrael A1-Template %
If a given path is incorrect, the program prints the message incorrect path
on the standard output.
mosser@azrael A1-Template % java -jar target/mazerunner.jar -i ./examples/straight.maz.txt -p 3F
inccorrect path
mosser@azrael A1-Template %
java -jar target/mazerunner.jar -i ./examples/tiny.maz.txt -method BFS
3F L 4F R 3F
java -jar target/mazerunner.jar -i ./examples/giant.maz.txt -method BFS -baseline righthand
Time spent loading the maze: 0.01 ms
Time spent with BFS method: 24.00 ms
Instructions (optimized): 320
Time spent with righthand method: 1929.00 ms
Instructions (baseline): 24282
Speedup: 75.88