(like this yummy stack of pancakes)
Imagine a stack that starts with a single pancake ("1")
(image source: https://en.wikipedia.org/wiki/Stack_(abstract_data_type), public domain)
Try playing around with this stack visualization tool (from David Galles at University of San Francisco) to get a feel for it.
Why only two operators?
The theme of "Freedom of Constraints" is important in software design.
(Also in any design or engineering context. And anything creative or artistic.)
In JavaScript, the easiest way to implement a stack is by using an array.
In fact, every array already knows how to push
and pop
.
Try this in a JavaScript console:
let fruits = []
fruits.push("apple")
fruits.push("banana")
fruits // [ 'apple', 'banana' ]
fruits.push("cherry")
fruits // [ 'apple', 'banana', 'cherry' ]
let fruit = fruits.pop()
fruit // 'cherry'
fruits // [ 'apple', 'banana' ]
Note that after a pop
, the stack's contents are changed. Pop removes and returns the final value from the array.
You may have heard the term "stack trace". A stack trace is part of most error messages, e.g.:
ReferenceError: fizz is not defined
at ReadStream.process.stdin.once (C:\Users\alex\code\hello.js:32:5)
at Object.onceWrapper (events.js:254:19)
at ReadStream.emit (events.js:159:13)
at addChunk (_stream_readable.js:265:12)
at readableAddChunk (_stream_readable.js:252:11)
at ReadStream.Readable.push (_stream_readable.js:209:10)
at TTY.onread (net.js:598:20)
In this context the term "stack" refers to the call stack.
The JavaScript interpreter is a program, and that program uses a stack internally to keep track of the list of functions that call functions that call functions that call...
For instance, in the above stack trace, you can see that the function TTY.onread
called the function ReadStream.Readable.push
, which called the function readableAddChunk
, and so on.
Now you know why a stack trace is upside down!
Using a stack, put the following program into a file called fib.js
...
let series = [0, 1];
while (series.length < 10) {
}
console.log(series);
...and complete it so that running node fib.js
prints
[ 0, 1, 1, 2, 3, 5, 8, 13, 21, 34 ]
which are the first 10 elements of the Fibonacci sequence.
Although series
is an array, please treat it like a stack -- that is, you can only use series.push()
and series.pop()
, not any other array operations.
Please split into pairs and do this right now. A solution is on the next slide.
let series = [0, 1];
while (series.length < 10) {
let b = series.pop();
let a = series.pop();
let c = a + b;
series.push(a);
series.push(b);
series.push(c);
}
console.log(series);
Note that we had to pop a
and b
in reverse order because it's a stack.
Note also that we had to push a
and b
back on to the stack after adding them to get c
.
Stacks are useful in many scenarios
/