In the previous chapter we used a stack diagram to represent the state of a program during a function call. The same kind of diagram can make it easier to interpret a recursive function.
A stack of 5 boxes. The top one is labeled main and is empty. The next four are all labeled βcountdownβ and respectively contain n = 3, n = 2, n = 1, n = 0.
There is one instance of main and four instances of countdown, each with a different value for the parameter n. The bottom of the stack, countdown with n = 0 is the base case. It does not make a recursive call, so there are no more instances of countdown.
The instance of main is empty because main does not have any parameters or local variables. As an exercise, draw a stack diagram for nLines, invoked with the parameter n = 4.
Refer to the nLines function below. It is the same as the nLines function defined on the previous page. How many instances of nLines would there be in the stack diagram if we begin with n = 4?