IT2153/IT2352/IT2553/IT2653/IT2852
Data Structures & Algorithms
Topic 05: Recursion
version 1.0
(Content adapted from:
• Data Structures & Algorithms using Python. Rance D. Necaise, Wiley, 1st
Edition, 2011.
• Data Structures & Algorithms in Python. Michael T. Goodrich, Roberto
Tamassia & Michael H. Goldwasser, Wiley, 1st Edition, 2013.)
Topic 05: Recursion AY2022/23 S1
Recursion
2
Topic 05: Recursion AY2022/23 S1
Recursion
Recursion
Recursive Functions
Classic example: Factorial function
Properties of Recursion
Recursion Call Tree
Run Time Stack
Topic 05: Recursion AY2022/23 S1
Recursion
Recursion is a process of solving problems by
subdividing a larger problem into smaller versions of
the itself and then solving the smaller, more trivial
parts.
Recursion is a powerful programming and
problem-solving tool, BUT not always the most
efficient.
However, in some instances, recursion is the
implementation of choice as it allows us to easily
develop a solution for a complicated problem
that may otherwise be difficult to solve.
4
Topic 05: Recursion AY2022/23 S1
Recursive Functions
A function that calls itself is known as a recursive
function.
Classic example – the Factorial function:
n! = 1· 2· 3· ··· · (n-1)· n
Recursive definition Python implementation
# Factorial function
# Assuming n >= 0
def factorial(n):
if n == 0:
return 1
else:
return n * factorial(n-1)
5
Topic 05: Recursion AY2022/23 S1
Properties of Recursion
All recursive solutions must satisfy three rules
or properties:
A recursive solution must contain a base case
A recursive solution must contain a recursive
case.
A recursive solution must make progress
towards the base case.
6
Topic 05: Recursion AY2022/23 S1
Properties of Recursion
Base case:
Terminating case and represents the smallest subdivision of
the problem.
Signals the end of the recursive calls.
In factorial(), the base case occurred when n = 0.
Recursive case:
The case when the recursive function calls itself.
In factorial(), the recursive case occurred when n > 0.
How does factorial() ensure that it makes
progress towards the base case? And what will
happen when it does not?
7
Topic 05: Recursion AY2022/23 S1
Visualizing Recursion
Example
Recursion call return 4*6 = 24 final answer
tree
call
factorial(4)
A box for each call return 3*2 = 6
recursive call factorial(3)
An arrow from each call return 2*1 = 2
caller to callee factorial(2)
An arrow from each call return 1*1 = 1
callee to caller factorial(1)
showing return value call return 1
factorial(0)
8
Topic 05: Recursion AY2022/23 S1
Recursion Call Tree
# A sample program
# containing three functions.
def main():
y = foo( 3 )
bar( 2 ) Draw the recursion
call tree.
def foo( x ):
if x % 2 != 0:
return 0 What is the output of
else:
return x + foo( x-1 ) the program?
def bar( n ):
if n > 0:
print( n )
bar( n-1 )
main()
Topic 05: Recursion AY2022/23 S1
Recursion Call Tree
# A sample program
# containing three functions.
def main():
y = foo( 3 )
bar( 2 )
def foo( x ):
if x % 2 != 0:
return 0
else:
return x + foo( x-1 )
def bar( n ):
if n > 0:
print( n ) NOTE: The edges are listed left to
bar( n-1 ) right in the order the calls are made.
main()
Topic 05: Recursion AY2022/23 S1
Behind the scenes …
Each time a function is called, an
activation record is created to maintain
information related to the function:
Return address – location of the next
instruction to be executed when the function
terminates
Local variables
When the function terminates, the
activation record is destroyed.
11
Topic 05: Recursion AY2022/23 S1
Behind the scenes …
System must:
Manage the collection of activation records.
Remember the order in which they were
created. WHY?
Allow the system to backtrack and return to the next
statement in the previous function when an invoked
function terminates.
Using a Run Time Stack Remember Stacks? LIFO? A
data structure to be discussed in a later topic.
12
Topic 05: Recursion AY2022/23 S1
Run Time Stack
# Consider executing this code:
def main():
y = fact( 2 )
When the main() When the factorial
routine is executed, the function, fact(), is
first activation record is called, the second
created and pushed onto activation record is created
the stack. and pushed onto the stack.
Topic 05: Recursion AY2022/23 S1
Run Time Stack
The factorial
function, fact(),
is recursively called
until the base case
is reached with a
value of n = 0.
Topic 05: Recursion AY2022/23 S1
Run Time Stack
When the base case
statement is executed, the
activation record for the
function call fact(0) is
popped from the stack,
and execution returns to
the function instance
fact(1).
This process continues until
all activation records have
been popped from the
stack and the program
terminates.
Topic 05: Recursion AY2022/23 S1