
Download the free Kindle app and start reading Kindle books instantly on your smartphone, tablet, or computer - no Kindle device required.
Read instantly on your browser with Kindle for Web.
Using your mobile phone camera - scan the code below and download the Kindle app.
Structure and Interpretation of Computer Programs - 2nd Edition (MIT Electrical Engineering and Computer Science) 2nd Edition
Purchase options and add-ons
- ISBN-100262510871
- ISBN-13978-0262510875
- Edition2nd
- PublisherThe MIT Press
- Publication dateSeptember 1, 1996
- LanguageEnglish
- Dimensions9 x 6 x 1.2 inches
- Print length657 pages
From #1 New York Times bestselling author Colleen Hoover comes a novel that explores life after tragedy and the enduring spirit of love. | Learn more
Frequently bought together

Customers who viewed this item also viewed
Editorial Reviews
About the Author
Gerald Jay Sussman is Panasonic Professor of Electrical Engineering at MIT.
Product details
- Publisher : The MIT Press; 2nd edition (September 1, 1996)
- Language : English
- Paperback : 657 pages
- ISBN-10 : 0262510871
- ISBN-13 : 978-0262510875
- Reading age : 18 years and up
- Grade level : 12 and up
- Item Weight : 2.31 pounds
- Dimensions : 9 x 6 x 1.2 inches
- Best Sellers Rank: #37,086 in Books (See Top 100 in Books)
- #2 in Compiler Design
- #2 in Software Programming Compilers
- #25 in Software Development (Books)
- Customer Reviews:
About the authors
Hal Abelson is Class of 1922 Professor of Computer Science and Engineering at Massachusetts Institute of Technology and a fellow of the IEEE. He is a founding director of Creative Commons, Public Knowledge, and the " "Free Software Foundation. Additionally, he serves as co-chair for the MIT Council on Educational Technology.
Discover more of the author’s books, see similar authors, read book recommendations and more.
Gerald Jay Sussman (February 8, 1947) is the Panasonic Professor of Electrical Engineering at the Massachusetts Institute of Technology (MIT). He received his S.B. and Ph.D. degrees in mathematics from MIT in 1968 and 1973 respectively. He has been involved in artificial intelligence research at MIT since 1964. His research has centered on understanding the problem-solving strategies used by scientists and engineers, with the goals of automating parts of the process and formalizing it to provide more effective methods of science and engineering education. Sussman has also worked in computer languages, in computer architecture and in VLSI design.
Bio from Wikipedia, the free encyclopedia. Photo by Massachusetts Institute of Technology, Department of Electrical Engineering and Computer Science [CC BY-SA 1.0 (http://creativecommons.org/licenses/by-sa/1.0)], via Wikimedia Commons.
Customer reviews
Customer Reviews, including Product Star Ratings help customers to learn more about the product and decide whether it is the right product for them.
To calculate the overall star rating and percentage breakdown by star, we don’t use a simple average. Instead, our system considers things like how recent a review is and if the reviewer bought the item on Amazon. It also analyzed reviews to verify trustworthiness.
Learn more how customers reviews work on AmazonCustomers say
Customers find this book essential for programmers of all levels, with one review highlighting how it guides readers to write a real Scheme interpreter. Moreover, the text receives positive feedback for its clarity, and customers consider it a worthwhile investment. However, the difficulty level receives mixed reactions, with several customers finding it challenging.
AI-generated from the text of customer reviews
Select to learn more
Customers find this book valuable for programming knowledge, describing it as a definitive guide to functional programming and essential reading for programmers of all levels.
"...real action between compiling and interpreting-- via the MATHEMATICS of "pure" functions, minus the confusion of changing states, variables and data..." Read more
"...The Wizard Book is about learning to think better...." Read more
"...The beauty of this book, however, is it leads you into Functional Programming without one even knowing it...." Read more
"...What the book does is give you a vocabulary and knowledge about programming that is hard to find anywhere else...." Read more
Customers find the book to be a fantastic and worthwhile purchase, with one customer noting its value as a supplemental resource.
"...But... worth it if you're willing to do the work!..." Read more
"...only worked part of the way through the book, but it is one of the best books I've had the pleasure of learning from...." Read more
"...watch the eponymous video lectures in parallel as they are thoroughly entertaining and on some occasions go into interesting theoretical discussions..." Read more
"...Overall, as I mentioned, the book is quite good. Just don't expect that because it is touted as an introductory text that it will be an easy read...." Read more
Customers praise the text quality of the book, describing it as awesome and clear, with one customer noting it is concise as the subject allows and another highlighting its comprehensive coverage of LISP.
"...The material is very dense and thorough. The beauty of this book, however, is it leads you into Functional Programming without one even knowing it...." Read more
"...But once you get acclimated, you begin to see the beauty and raw power it holds...." Read more
"...And it is here that the book really shines, progressively refining the readers' idea of what a computer program essentially is through multiple..." Read more
"...of bad things, but chief among them the ridiculous assumptions the author makes about the reader...." Read more
Customers find the book fun to read, with one customer noting it provides a great learning experience and includes interesting and challenging exercises.
"...is that they introduce a lot of topics and do not shy away from interesting and challenging exercises...." Read more
"...that you can run and manipulate yourself, which makes for a great learning experience." Read more
"...the first three chapters of exercises, and they are challenging and fun...." Read more
"...It is filled with intelligence and wisdom. It is also a lot of fun." Read more
Customers have mixed opinions about the difficulty level of the book, with some finding it challenging and others describing it as very difficult.
"...dense; but the authors are masterful teachers and the exercises are very effective. Scheme is a fascinating language...." Read more
"...Simple does NOT equal easy!..." Read more
"...Another nice thing about the book is that it constantly keeps challenging you: the exercises get progressively more difficult and there are very few..." Read more
"...That being said, the book suffers from a few flaws that make is less than easy-going for probably the majority of readers...." Read more
Reviews with images

Refunded immediately after I received it
Top reviews from the United States
There was a problem filtering reviews. Please reload the page.
- Reviewed in the United States on July 11, 2013Inductive reasoning aims at simplifying functions just enough to make them general. Simple does NOT equal easy! When Functional Programming (and its predecessors-- combinatory logic (1925) and lambda calculus (1930)) were first invented, they were aimed at clarifying mathematical logic. This "holding variables constant" or binding or eliminating them for "pure" (mathematical) functions, has been extended to Functional Programming, initially to better understand what programming is in general, then to evaluate mathematical functions while avoiding some of the complicating factors (side effects) of imperative/procedural programming.
Because of this, when you think of a function in imperative, you immediately think of variables, and such functions can very easily morph both at the algo/function f(x)-> g(x) level, and at the x (variable level) itself (data changing as you execute). In functional programming (the subject of this text), a function is, well, a MATH function! So, evolving from math, and consisting OF math, it would be a little surprising to criticize the fact that this IS A MATH BOOK. (Sorry, it is). On the other hand, holding those variables constant and looking directly at functional mappings (particularly recursion) can "AHA" us into seeing how computers and programming "really" work without the complications of heavy imperative morphs.
After C# 3 and in some Perl, these tried and true oops also have some functional classes now, so we are moving toward a more hybrid world, making this book FAR from out of date, even though it is "temporally" older. As well, some of your favorite math, research and engineering programs (Maple, Mathematica and R, for example) have numerous functional features. The old FP standbys are, of course, Lisp, Scheme, Hope, Haskell, Clojure, Racket, Hope, Scala, F#, etc. which you probably think of more as "math" programs. But, hopefully not a surprise, SQL itself strives at far less mutable value structures than imperative, and thus tilts toward functional also.
FP, to be very honest, WAS designed to teach and understand programming (at compile/interpret levels, not necessarily algorithms, computational complexity or even advanced data structures), not originally create useful programs! "R" and many others have proved that to be aiming low, and the newer FP books do of course get deeply into more recent data structures.
Thus, the reason for so many negative reviews! This is NOT your usual "how to program" or even "what are programs" text-- it really is about linking mathematics and computer science at both high and deep levels. So, if you aren't really up on math (from basics like sets and real number mappings all the way up to Lie Algebras and tensors), you might get lost with this rare gem of a book. On the other hand, the pain of working through it will give you a perspective on computer science that will forever change your point of view. Even if you code all day like I do, you'll LOVE taking this journey both to the 30,000 foot level, as well as down to the real action between compiling and interpreting-- via the MATHEMATICS of "pure" functions, minus the confusion of changing states, variables and data we play with every day in the imperative version of functions. Don't believe that this "simplification" makes things easier to get-- unless you know functions from a deep math view, this will be a tough climb.
But... worth it if you're willing to do the work! Most other books on "discrete math" are really UI catch ups for all the computer/math that's now been removed from High School curricula, making this one of the few "real deals" that are at a bright, high undergrad level, NOT catch up. By removing calculus from HS requirements, we're teaching 2,500 year old math, and adding the basics brings us up to 1666 or so. This book rapidly catapults our function math vs. function computing into the new century! Highly recommended IF you're not turned off by advanced math functions, mappings, properties, etc. The next time someone asks how a special or CAS function can run faster interpreted than compiled, you'll have a MUCH different answer! And of course the heart of all dynamical systems today includes differential equations, which are essentially recursive function processing.
BEFORE AND AFTER: If you're not "quite" ready for this level of FP and Lisp, you can get a great, inexpensive backgrounder with Dover's An Introduction to Functional Programming Through Lambda Calculus (Dover Books on Mathematics). Mathwise, many Dover books on the keyword recursive functions will help. For a freebie intro, Graham's famous "on lisp" is now available as a free download, and is a bit above the level of this book. For the "greatest intellectual programming book ever written" (far beyond the level of this book, covering advanced Lisp macros, closures, etc.), check out (AFTER reading this): Let Over Lambda. Only 1% of programmers really understand Common Lisp, and only 1% of those would tackle the unhygenic macros in Let Over-- yet it is so intellectualy challenging that coders and engineers at all levels are astonished when they read it. Shows how high the bar can really get! (Lisp tends to do that, right?).
IS IT DATED? In answer to a bunch of emailers asking that, NO-- the principles of functional are still the same, even if Common Lisp and Scheme have been updated. In fact, today, combinations of functional, imperative and logical are happening more and more (called mixed paradigm programming). However, if you want a GREAT, VERY RECENT book as both a warm up and an update to Abelson, try this little beauty by the same author as the Little Schemer: Realm of Racket: Learn to Program, One Game at a Time!. It will fill in where Abelson is a little out of date AND prepare you for his depth. WARNING: PLEASE BE SURE to get the 2nd Edition of Abelson, he updated it significantly for the relationship between time and memory, a relationship that is even today undergoing a LOT of research in many fields.
- Reviewed in the United States on January 27, 2009You need it, too. I won't pretend to have more useful insight into the art and craft of programming, or into SICP's relationship to it, than Paul Graham or Peter Norvig- if you want to know which reviews to trust, look these cats up.
The discussion in the reviews usually concludes that this is the book that separates the computer scientists from the mere programmers. There is a definite logic to this. If you want a book that will have you churning out code that does something helpful in half an hour(because you don't think the several ways to calculate the Fibonacci Sequence are helpful), by all means, pick up Learning Perl or just read the Python documentation. They are great tools. If, however, you want to tool up on problem-solving technique a whole level or three higher up, SICP is for you. The Wizard Book is about learning to think better.
Here is where I diverge from the idea that this book is for only computer scientists, though. I am an artist, graduated from college with a BA in art, going to graduate school for an MFA. SICP is one of the books that changed how I work and think. It will make you a better programmer if you read (and reread (and reread)) it in the same way that learning Latin will make you understand language itself in a whole new way. I use ideas from SICP constantly, to design software, but also to design staircases. The book is slow-going, no doubt about it, but you'll have a whole new mental toolset at the end.
One caveat- this book is freely distributed in its entirety on MIT's website. I still bought a copy, though: who knows how long this internet thing will last, but SICP is going to be relevant forever.
- Reviewed in the United States on March 22, 2013I bought this book at the recommendation of a speaker on Functional Programming at a Computing Conference. It was on his list of the 10 most important books in Computer Programming. I am doing the "paradigm" shift to Functional Programming and Learning Clojure, so I thought it would be a good book to have on my Shelf. And the Paperback version was less expensive than the hardback.
It arrived very quickly in excellent shape.
I've been developing software since the 70's and have undergone the shifts in COBOL to Yourdon's Structured Design, to C then C++, OOP in Java and C++ and now to Clojure and Scala. I'm using this book as a supplement to learning Clojure, although the code is in Lisp. The material is very dense and thorough. The beauty of this book, however, is it leads you into Functional Programming without one even knowing it. I am only part way through it (converting the examples from Lisp to Clojure as I go) and my understanding of FP has grown by leaps and bounds.
- Reviewed in the United States on August 26, 2014This was the book that made me want to be a computer programmer. When I read it, I had no knowledge of programming beyond a little Pascal, and rudiments of C.
It had a massive impact on me. It consumed me, to the point where I had difficulty finishing assignments for my classes (I did not study CS as an undergrad). What the book does is give you a vocabulary and knowledge about programming that is hard to find anywhere else.
The text, the examples and exercises, have a mathematical flavor, and that may turn off many potential readers, who would rather gadget around than find elegant solutions for the 8-queens puzzle or efficient algorithms to compute Fibonacci numbers.
I've lent this book to several friends who were interested in learning to program, and in all cases they have returned it to me, saying it went over their heads.
There seem to be two camps in computer programming:
- the gadgeteers, who want to hook devices together and make them do fun things
- the scientists, who appreciate computing as a medium in itself
This book is for the second type.
Top reviews from other countries
-
Amazon CustomerReviewed in Brazil on July 21, 2017
5.0 out of 5 stars Conteúdo bom, material ruim!
SICP é um clássico da ciência da computação, seu conteúdo é fenomenal, sem sombra de dúvidas!
Quem é um verdadeiro cientista da computação ou almeja tornar-se um, ler essa obra é um dever.
Ao receber o livro fiquei decepcionado com a capa do livro a qual veio com a borda estragada o que me
obrigou a encapar para uma conservação mais prolongada, sem contar que algumas páginas do livro vieram
manchadas devido a erros de impressão.
A entrega também foi decepcionante. Após uma tentativa falha de entrega, deixei instruções a Amazon com
os horários que eu estaria em casa além de que eu deveria ser o único que deveria receber o produto e caso
não me encontrassem em casa novamente poderiam entregar o produto no meu local de trabalho o qual
fica a 700 metros de minha residência. Entretanto quando retornaram 3 dias depois foram em um
horário o qual eu não estava e deixaram com um vizinho. Muitas outras coisas me decepcionaram além destas
citadas acima dois dias depois que eu efetuei a compra, o produto estava 90 reais mais barato. Apenas não o devolvi
pela razão dessa obra clássica ter um conteúdo muito valioso, o que a torna indispensável para o meu desenvolvimento intelectual.
- Ravi PunReviewed in Australia on August 30, 2024
4.0 out of 5 stars Pretty good condition
The book is in good condition and i havent have much problems with it for now
Ravi PunPretty good condition
Reviewed in Australia on August 30, 2024
Images in this review
- Vishy IyerReviewed in the United Kingdom on February 3, 2019
5.0 out of 5 stars A must read for every serious programmer
This book has to be read as a self study. Mind you, this is not an easy read as a self study book. It will frustrate you no end; but the results will surely be rewarding.
- Amazon CustomerReviewed in Canada on July 11, 2019
5.0 out of 5 stars good stuff
5/5 would read again
-
JorgeReviewed in Mexico on October 18, 2021
5.0 out of 5 stars Entendimiento general de bases de programación
De momento voy en el 2do. capitulo del libro. Tiene bastantes ejercicios por hacer que creo aumentan enormemente la comprensión de lo que el autor habla, por lo que es un punto bueno a comentar, ya que eso es material para bastante tiempo. En general me gusta cómo presenta los conceptos el autor, porque si bien algunas cosas suelen ser "conocidas" como los "procedures", el autor lo presenta de manera que te hace comprender por qué están ahí y por qué tienen valor en un lenguaje de programación.