From 95a47efad1d99418bc8fc876ed28b1960d32155b Mon Sep 17 00:00:00 2001 From: ExeVirus <ddsallad@gmail.com> Date: Fri, 5 Feb 2021 22:23:57 -0500 Subject: [PATCH] Working Mazes, only odd sizes allowed, obviously. Takes about 3 seconds for 300x500, normally a 61x61 will suffice for the hardcore --- maze.lua | 78 +++++++++++++++++++++++++++++--------------------------- 1 file changed, 41 insertions(+), 37 deletions(-) diff --git a/maze.lua b/maze.lua index 89ba4e8..4ac1d9c 100644 --- a/maze.lua +++ b/maze.lua @@ -50,60 +50,61 @@ local function getNextPoint(current_point,height,width,last_dir) --keep trying till we get a valid direction while(1) do local dir = math.random(3) - if last_dir == 1 then --west + if last_dir == 3 then --east + if dir == 1 then --north - if current_point[2]-2 > 0 then - return {current_point[1],current_point[2]-2}, 2 + if current_point[1]-2 > 0 then + return {current_point[1]-2,current_point[2]}, 2 end elseif dir == 2 then --east - if current_point[1]+2 <= width then - return {current_point[1]+2,current_point[2]}, 3 + if current_point[2]+2 <= width then + return {current_point[1],current_point[2]+2}, 3 end else --south - if current_point[2]+2 <= height then - return {current_point[1],current_point[2]+2}, 4 + if current_point[1]+2 <= height then + return {current_point[1]+2,current_point[2]}, 4 end end - elseif last_dir == 2 then --north + elseif last_dir == 4 then --south if dir == 1 then --east - if current_point[1]+2 <= width then - return {current_point[1]+2,current_point[2]}, 3 + if current_point[2]+2 <= width then + return {current_point[1],current_point[2]+2}, 3 end elseif dir == 2 then --south - if current_point[2]+2 <= height then - return {current_point[1],current_point[2]+2}, 4 + if current_point[1]+2 <= height then + return {current_point[1]+2,current_point[2]}, 4 end else --west - if current_point[1]-2 > 0 then - return {current_point[1]-2,current_point[2]}, 1 + if current_point[2]-2 > 0 then + return {current_point[1],current_point[2]-2}, 1 end end - elseif last_dir == 3 then + elseif last_dir == 1 then --west if dir == 1 then --south - if current_point[2]+2 <= height then - return {current_point[1],current_point[2]+2}, 4 + if current_point[1]+2 <= height then + return {current_point[1]+2,current_point[2]}, 4 end elseif dir == 2 then --west - if current_point[1]-2 > 0 then - return {current_point[1]-2,current_point[2]}, 1 + if current_point[2]-2 > 0 then + return {current_point[1],current_point[2]-2}, 1 end else --north - if current_point[2]-2 > 0 then - return {current_point[1],current_point[2]-2}, 2 + if current_point[1]-2 > 0 then + return {current_point[1]-2,current_point[2]}, 2 end end - else + else --north if dir == 1 then --west - if current_point[1]-2 > 0 then - return {current_point[1]-2,current_point[2]}, 1 + if current_point[2]-2 > 0 then + return {current_point[1],current_point[2]-2}, 1 end elseif dir == 2 then --north - if current_point[2]-2 > 0 then - return {current_point[1],current_point[2]-2}, 2 + if current_point[1]-2 > 0 then + return {current_point[1]-2,current_point[2]}, 2 end else --east - if current_point[1]+2 <= width then - return {current_point[1]+2,current_point[2]}, 3 + if current_point[2]+2 <= width then + return {current_point[1],current_point[2]+2}, 3 end end end @@ -144,17 +145,17 @@ end local function onChain(chain,point) for _,v in pairs(chain) do - if point == v then return true end + if point[1] == v[1] and point[2] == v[2] then return true end end return false end local function backTrack(chain, point) for i=#chain,1,-1 do - if point == chain[i] then + if point[1] == chain[i][1] and point[2] == chain[i][2] then return point, chain else - table.remove(chain) + table.remove(chain,i) end end error("it was onChain, but not found....") @@ -167,12 +168,13 @@ function sleep(n) -- seconds end local function wilsonsAlgo(maze,view) - local view_count_down = 3 + local view_count_down = 1 local current_point = findNextStarting(maze) local last_dir = 2 --1 = west, 2 = north, 3=east, 4=south + local next_point = {} local chain = { current_point } while(1) do --exited with return statement - local next_point, last_dir = getNextPoint(current_point,maze.height,maze.width,last_dir) + next_point, last_dir = getNextPoint(current_point,maze.height,maze.width,last_dir) if onChain(chain,next_point) then current_point, chain = backTrack(chain,next_point) elseif maze[next_point[1]][next_point[2]] == 1 then @@ -194,7 +196,7 @@ local function wilsonsAlgo(maze,view) os.execute("cls") viewMaze(maze, chain) sleep(1) - view_count_down = 3 + view_count_down = 5 end end end @@ -228,8 +230,10 @@ local function Generate_Maze(width, height, view) maze.height = height --initialize first point math.randomseed(os.time()) - local spot = findNextStarting(maze) - maze[spot[1]][spot[2]] = 1 + local x = math.random(math.floor(width/2))*2+1 + local y = math.random(math.floor(height/2))*2+1 + --local spot = findNextStarting(maze) + maze[y][x] = 1 --Execute Algorithm wilsonsAlgo(maze, view) @@ -238,6 +242,6 @@ local function Generate_Maze(width, height, view) return maze end -local maze = Generate_Maze(21,21,"true") --Only odd sizes allowed +local maze = Generate_Maze(531,251,"false") --Only odd sizes allowed os.execute("cls") viewMaze(maze)