An algorithm that generates a level for roguelike games.
There's also a C# port.
- Divide the map into a grid of evenly sized cells.
- Pick a random cell as the current cell and mark it as connected.
- While the current cell has unconnected neighbor cells: 3. Connect to one of them. 3. Make that cell the current cell.
- While there are unconnected cells: 4. Pick a random connected cell with unconnected neighbors and connect to one of them.
- Pick zero or more pairs of adjacent cells that are not connected and connect them.
- Within each cell, create a room of random shape.
- For each connection between two cells: 7. Create a random corridor between the rooms in each cell.
- Place staircases in the cell picked in step 2 and the lest cell visited in step 3ii.
###### ############# ######
######## #....# ######## #...........###....#########
#......###....###########......# #...##.......##............#
#..............##......##......#####...##.............###.....#
#......##......##......................##......###....# #.....#
#......###.....##......##......##########......# #....# ####.##
#......# #.....##......######### #......# #....# #..#
####.### #####.#####.### ######## ###### ###.##
#..# #.#####.## ###### ##### #...##
##.#### ###.##.....# #....# #...# ###....#
#.....# #..........# #....############...# ####......#
#.....# #...##.....# #..............#....# #....#....#
#.....# #...##.....# ###.######..........# #...##....#
#.....# #...##.....# #.# #.....####.# #...##....#
#.....# ############ #.# #.....# #.# ###...##....#
#####.# #.### ####### #.# #...######.##
###.# ###### ###...## ###.## #.### ##.###
#...# #....# ########......# #....# ##.##### #....#
#...###....# #.....##......##########....# #......# #....#
##...##.....# #.....##......##......##....# #......# #....#
#...........####.............##......##....# #......###....#
#....###.............##......##......##....# #.............#
#.#### #....####.....##......##............# ##########....#
#.# ####.# ##################.########## ##.###
#.# ####.## ###### #.#### #.#
#.# #.<...# #....########## #....# #.####
###.## #.....###.............# #....######### ###### #....#
#....# #.....##.....##.......# #............# #....# ##...#
#....#####.....##.....##.......# #....###.....# #....######...#
#..............##.######.......# #....# #.>...# #.............#
##.#######.....##.# #.......# ###### ####### #....######...#
#..# ########.# #####.### ##.### ##.##
##.#### #.###### #.# ####### ##.## ##..#
#.....# ########......#####.# #.....# #...# #...#
#.....###.............##....# #.....# #...# #...#
#..............#......##....#####.....######### #...# #...#
#########.....##......##......................###...# #####
#.....##......##...#############............#
########......###### #......###...#
######## ######## #####
Created as I reworded this algorithm (link is now broken, can't find a mirror) to make it easier to follow.