Stacks and Queues
Stack Push/Pop
Push values onto a stack and pop them back in last-in, first-out order.
Algorithm
The replay uses the same three values in every language, so this Bash DSA implementation can be compared directly with the rest of the DSA track.
Basic Implementation
basic.sh
#!/usr/bin/env bash
set -euo pipefail
render() {
local out=""
for value in "$@"; do
if [[ -n "$out" ]]; then out+=" -> "; fi
out+="$value"
done
printf '%s\n' "$out"
}
stack=()
for value in 10 20 30; do stack+=("$value"); done
popped=()
while (( ${#stack[@]} > 0 )); do popped+=("${stack[-1]}"); unset 'stack[-1]'; done
render "${popped[@]}"
Complexity
- Time: O(1) per push/pop
- 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.
top
The top is the most recently pushed value.
LIFO
A stack removes values in last-in, first-out order.