TY - JOUR
T1 - The structure and interpretation of the computer science curriculum
AU - Felleisen, Matthias
AU - Findler, Robert Bruce
AU - Flatt, Matthew
AU - Krishnamurthi, Shriram
PY - 2004/7
Y1 - 2004/7
N2 - Twenty years ago Abelson and Sussman's Structure and Interpretation of Computer Programs radically changed the intellectual landscape of introductory computing courses. Instead of teaching some currently fashionable programming language, it employed Scheme and functional programming to teach important ideas. Introductory courses based on the book showed up around the world and made Scheme and functional programming popular. Unfortunately, these courses quickly disappeared again due to shortcomings of the book and the whimsies of Scheme. Worse, the experiment left people with a bad impression of Scheme and functional programming in general. In this pearl, we propose an alternative role for functional programming in the first-year curriculum. Specifically, we present a framework for discussing the first-year curriculum and, based on it, the design rationale for our book and course, dubbed How to Design Programs. The approach emphasizes the systematic design of programs. Experience shows that it works extremely well as a preparation for a course on object-oriented programming.
AB - Twenty years ago Abelson and Sussman's Structure and Interpretation of Computer Programs radically changed the intellectual landscape of introductory computing courses. Instead of teaching some currently fashionable programming language, it employed Scheme and functional programming to teach important ideas. Introductory courses based on the book showed up around the world and made Scheme and functional programming popular. Unfortunately, these courses quickly disappeared again due to shortcomings of the book and the whimsies of Scheme. Worse, the experiment left people with a bad impression of Scheme and functional programming in general. In this pearl, we propose an alternative role for functional programming in the first-year curriculum. Specifically, we present a framework for discussing the first-year curriculum and, based on it, the design rationale for our book and course, dubbed How to Design Programs. The approach emphasizes the systematic design of programs. Experience shows that it works extremely well as a preparation for a course on object-oriented programming.
UR - http://www.scopus.com/inward/record.url?scp=3042804927&partnerID=8YFLogxK
UR - http://www.scopus.com/inward/citedby.url?scp=3042804927&partnerID=8YFLogxK
U2 - 10.1017/S0956796804005076
DO - 10.1017/S0956796804005076
M3 - Review article
AN - SCOPUS:3042804927
SN - 0956-7968
VL - 14
SP - 365
EP - 378
JO - Journal of Functional Programming
JF - Journal of Functional Programming
IS - 4
ER -