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 C DSA implementation can be compared directly with the rest of the DSA track.
Basic Implementation
basic.c
#include <stdio.h>
void print_values(int values[], int count) {
for (int i = 0; i < count; i++) {
if (i > 0) printf(" -> ");
printf("%d", values[i]);
}
printf("\n");
}
int main(void) {
int stack[3];
int top = 0;
int popped[3];
int count = 0;
int values[] = {10, 20, 30};
for (int i = 0; i < 3; i++) stack[top++] = values[i];
while (top > 0) popped[count++] = stack[--top];
print_values(popped, count);
return 0;
}
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.