Implementation of the binary tree algorithm for constructing a randomly generated maze using the SFML library.
This code was used in the game Battle Tanks
Its essence is to pave the way in a random direction from each cell of the field: in my implementation, either up or to the right (depending on the offset you choose). We process only 1 cell per unit of time, therefore, we can generate labyrinths of infinite size, preserving only the final result (labyrinth) without the need to store any secondary information.
This generation method has two side effects:
-
Labyrinths have a strong diagonal displacement and the absence of dead ends in its direction. Look at the screenshots below and you will see that each of the corridors tends to the upper right cell, and, as a result, has exactly one path to it, and there is no dead end anywhere:
-
Two empty corridors on the sides of the maze. When the algorithm “digs” to the end of the row / column, it has no choice but to continue the path in one single direction, creating empty “borders”.
By the way, the name does not just coincide with the data structure. The result of his work is a random binary tree in which from each cell (vertex) there is exactly 1 path towards the root (parent vertex), and, accordingly, exactly 1 path to any other cell. As a result, any cell has no more than 3 connections with its neighbors.
Formal algorithm (for northeast bias):
- Select an initial cell;
- Choose a random direction to pave the way. If a neighboring cell in this direction goes beyond the boundaries of the field, dig a cell in the only possible direction;
- Go to the next cell;
- Repeat 2-3 until all cells have been treated;