Stacks and Queues
Queue from Two Stacks
Implement queue behavior with an input stack and an output stack.
Algorithm
The replay uses the same three values in every language, so this Lua DSA implementation can be compared directly with the rest of the DSA track.
Basic Implementation
basic.lua
local function render(values)
local parts = {}
for i, value in ipairs(values) do parts[i] = tostring(value) end
return table.concat(parts, " -> ")
end
local in_stack = {}
local out_stack = {}
for _, value in ipairs({10, 20, 30}) do table.insert(in_stack, value) end
while #in_stack > 0 do table.insert(out_stack, table.remove(in_stack)) end
local removed = {}
while #out_stack > 0 do table.insert(removed, table.remove(out_stack)) end
print(render(removed))
Complexity
- Time: O(1) amortized per operation
- Space: O(n)
Implementation notes
- Keep the explicit stack/queue operations. Library shortcuts that only produce the final list hide the data-structure behavior this lesson is meant to replay.
- The final output uses a deterministic
a -> b -> cformat for cross-language comparison.
input stack
Enqueue pushes new values onto the input stack.
output stack
When the output stack is empty, transferring all input values reverses them into dequeue order.