The approach to teaching recursion in introductory programming courses has changed little during the transition from procedural to object-oriented languages. It is still common to present recursion late in the course and to focus on traditional, procedural examples such as calculating factorials or solving the Towers of Hanoi puzzle. In this paper, we propose that the shift to object-oriented programming techniques calls for a significant shift in our approach to teaching recursion. First, we argue that in the context of object-oriented programming students should be introduced to examples of simple recursive structures such as linked lists and methods that process them, before being introduced to traditional procedural examples. Second, we believe that this material should be presented before students are introduced to structures such as arrays. In our experience, the early presentation of recursive structures provides the opportunity to reinforce the fundamentals of defining and using classes and better prepares students to appreciate the reasons to use classes to encapsulate access to other data structures when they are presented.
[1]
Kim B. Bruce,et al.
Event-driven Programming can be Simple Enough for CS 1
,
2001
.
[2]
Kim B. Bruce,et al.
A library to support a graphics-based object-first approach to CS 1
,
2001,
SIGCSE '01.
[3]
Kim B. Bruce,et al.
Java: An Eventful Approach
,
2005
.
[4]
Kim B. Bruce,et al.
Event-driven programming is simple enough for CS1
,
2001
.
[5]
Dung Zung Nguyen,et al.
Patterns for decoupling data structures and algorithms
,
1999,
SIGCSE '99.
[6]
Matthias Felleisen,et al.
A little Java, a few patterns
,
1997
.
[7]
Peter B. Henderson,et al.
Teaching recursion as a problem-solving tool using standard ML
,
1989,
SIGCSE '89.
[8]
Cheng-Chih Wu,et al.
Conceptual models and cognitive learning styles in teaching recursion
,
1998,
SIGCSE '98.
[9]
Matthias Felleisen,et al.
How to Design Programs
,
2001
.