Hacker News Comments on
Concrete Mathematics: A Foundation for Computer Science (2nd Edition)
Hacker News Stories and CommentsAll the comments and stories posted to Hacker News that reference this book.
I'm going to go a completely different direction from other recommendations and say Concrete Mathematics by Knuth and Patashnik. They will definitely be able to use skills from analysis and calculus here, but there are so many additional tools in this book that it's very much a worthwhile digression. The marginal notes are great, as well!
I own this book, and it's a favorite of mine.
⬐ kolinkoWhen I saw the title, this was the first book that came to my mind. Very nicely written, possibly the best math book I've read (as a Computer Science MSc)⬐ javajoshGreat pick. Note: you can get it for $20 less AND support a local used book store if you buy it from alibris. https://www.alibris.com/Concrete-Mathematics-A-Foundation-fo...
Or concrete, as suggested by Knuth, Graham, and Patashnik in their book, "Concrete Mathematics: A Foundation for Computer Science".
⬐ daveslashThe "Concrete Math" book title is a play on words - combining continuous and discrete. From the preface: "When DEK taught Concrete Mathematics for the first time.... [h]e announced that, contrary to the expectations of some of his colleagues, he was _not_ going to teach the Theory of Aggregates, not Stone's Embedding Theorem, not even the Stone-Cech compactification. (Several students from the civil engineering department got up and quietly left the room). [Edit]: Typo/Spelling fix.
Someone asked this a few months ago and the book that was referred was Concrete Mathematics by Knuth (https://www.amazon.com/Concrete-Mathematics-Foundation-Compu...) which I have since purchased and have enjoyed re-learning from college. Highly recommended, and should cover all you need to know. Very approachable text.
Donald Knuth is actually a great writer and teacher. Try Concrete Mathematics instead of TAOCP, it is a shorter and easier introduction: http://amzn.com/0201558025.
It is humorous and it includes notes from past students in the margin. I really enjoyed it.
Shameless plug: I wrote an illustrated book on algorithms that aims to be an easier read than TAOCP, CLRS and others: http://amzn.com/1617292230.
⬐ mjcohenNot available yet.⬐ egonschieleThe first chapter is here: https://manning-content.s3.amazonaws.com/download/4/b78a5a1-...
(not the final formatting)⬐ rurbanI prefer the Sedgewick illustrations. Yours are targetting kids and is too verbose.
This is always a good topic with numerous HN submissions and comments:
Just from a search, there are some great results:
Here are some other excellent mathematics books:
1. Mathematics: Its Content, Methods and Meaning
Containing the thoughts and direction of numerous mathematicians including Kolmogorov, this is a great survey of the field of mathematics. It touches upon Analysis, Analytic Geometry, Probability, Linear Algebra, Topology, and more. [1.]
2. Concrete Mathematics: A Foundation for Computer Science
Containing the thoughts and direction of mathematician and computer scientists such as Donald Knuth, this is a great reference for computer science related mathematical concepts focusing on continuous and discrete concepts. [2.]
⬐ throwahdhwAny HN recommendations for a good thorough book on Lambda Calculus? Preferably creative commons if such a text exists.⬐ dpflanHave you seen this post on StackExchange/Mathematics? This may be a good start. I can't personally recommend any. Of course, good luck learning!
You mean Concrete Mathematics, by Ron Graham^, Don Knuth^^, and Oren Patashnik?
I thought it was just an advertisement for Computer Concrete Roman (Knuth's other font family) and the Zapf(?) Euler math fonts.
^ Yes, that Ron Graham.
^^ Yes, that Don Knuth.
^^^ I don't recognize Patashnik. Sorry.
CLRS is quite 'academic' and requires good understanding of mathematics. It's a great book, but not a good one for beginners, imo. It will be difficult as self study for first timers. You can start with Datastructures and Algorithm Analysis in C by M. A. Weiss. One more alternative is The Algorithm Design Manual by S. Skiena. It's also good and focuses more on algorithm, implementation (as opposed to math-y stuff of CLRS). If I were you, I would get both the books and read alternatively. Don't miss out on exercises, they are very important.
I also suggest you to join this Coursera course, Algorithms: Design and Analysis by Tim Roughgarden. Currently the course is open, so you can sign up for classes. The course is offered in two parts, complete both of them.
Once you are comfortable with basic concepts start solving questions/puzzles online on sites like SPOJ, UVa, (YC-funded) HackerRank. You could try TopCoder also, but the questions are bit difficult. Hope this helps.
PS - You should study math, because it is important in Algorithms Analysis. You could try reading required parts of Concrete Mathematics by Knuth or as you come across new concepts, Google and understand them.
 - http://www.spoj.com
 - http://hackerrank.com
 - http://www.topcoder.com
⬐ brudgersI would also recommend Roughgarden's Coursera classes, however, I would strongly recommend waiting for a live session.
A book I think is informative from a practical perspective is Algorithms in a Nutshell from O'Reilly Press. As always with Amazon I would look for a used copy.⬐ avinasshBut no need to wait at this moment, as class is live. However I also agree that live session is recommended and actually fun. Some of the Community TAs are really good, which one will miss if attended non-live version of class.
Concrete Mathematics is probably a more relevant Knuthwerk.
For what it's worth, Rosen's introductory text on discrete mathematics is pretty good as well. (This sort of math crops up all the time in formal CS, for those of you who might otherwise wonder wtf discrete has to do with anything.) http://www.amazon.com/s/ref=nb_sb_ss_i_0_13?url=search-alias... (The study guide that is available to go with it is worth the money, imho.)
The Graham, Knuth, Patashnik book on concrete mathematics (a bit of a play on words for continuous and discrete) is a quality work as well but written to a considerably higher level that may or may not be pleasant to contend with depending on the reader's background. http://www.amazon.com/Concrete-Mathematics-Foundation-Comput...
Well you haven't mentioned how much math you're familiar with. But I'll assume that you know school level mathematics and are looking to learn more about the math mostly used in computer science. Get Concrete Mathematics( http://www.amazon.com/Concrete-Mathematics-Foundation-Comput... ) by Graham, Knuth & Patashnik - It's based on the course taught at Stanford since 1970 & it's really really good. Another book I think you should get is Meta Math: The quest for Omega( http://www.amazon.com/Meta-Math-Quest-Gregory-Chaitin/dp/140... ) by Gregory Chaitin. It's not really a math course book, and is mostly the authors take on his favorite topics in math, but if you want to improve your thinking process then this book will definitely give you a different perspective.
_Concrete Mathematics_  is a good book that is fun to work through. The book can be considered an introduction/prerequisite to Knuth's _The Art of Computer Programming_ series , which contains much mathematics. If you would like a book that is not so difficult, _Introduction to Algorithms_  (aka "CLRS") is also highly recommended.
This looks excellent. I also heartily recommend Knuth's Concrete Mathematics (http://www.amazon.com/Concrete-Mathematics-Foundation-Comput...)
⬐ swordswinger12This book has a great chapter on recurrence relations. Saved my ass in an algorithms course iirc.
Has anyone read both this and Knuth's Concrete Mathematics? http://www.amazon.com/Concrete-Mathematics-Foundation-Comput... How do they compare with each other?
My recommendation is "Concrete Mathematics", by Graham, Knuth, and Patashnik. (http://www.amazon.com/Concrete-Mathematics-Foundation-Comput...)
It is excellently written, but by no means a light read. If you put in the time and effort, you will come out on the other side with a great foundation, and deep understanding and mastery of the topics.
However, it's definitely not an introductory book, and some background in math will be very helpful.
I'd also check out these threads:
Ask HN: Best Mathematics book for complete noobie? http://news.ycombinator.com/item?id=755043
Ask HN: good math books http://news.ycombinator.com/item?id=665029
Ask HN: Learning advanced math http://news.ycombinator.com/item?id=1753029
I've seen a few people recommend The Princeton Companion to Mathematics(PCM) http://press.princeton.edu/titles/8350
I own this book and while I do agree it's a great book for getting a 10000 foot view about topics in mathematics it's not really a book one read to learn the math that the poster is asking for.
I agree with another post here that said studying is doing problems and being able to do them again a week later without having to consult the text again.
PCM isnt a good book for learning calculus, discrete math, probability or statistics( what the posters wants to learn) simply because it isn't designed to teach them. There are no problems/solutions in the book to try.
If you really want one book then I'd recommend Concrete Mathamatics http://www.amazon.com/Concrete-Mathematics-Foundation-Comput... by Graham, Knuth and Patashnik. It has relevant topics and problem sets that you can work through to see if you truly did learn anything when reading it.
It depends what level you are already on. At some point, you might like to read Concrete Mathematics: A Foundation for Computer Science
which is an enjoyable book, but which presupposes a fairly strong background in math.
An easier book that is good preparation for computer science is Mathematics: A Discrete Introduction,
which is very readable and full of information that will get you ready for computer science concepts and for other math reading.
Browse the books on this bibliography page
for lots of suggestions compiled by someone deeply interested in computer science.
Assuming you've been coding for a while, I'd recommend taking a look at Concrete Mathematics ( http://www.amazon.com/Concrete-Mathematics-Foundation-Comput... ). It's a challenging book, but it's extremely well-written, and you should be able to get through it with a minimal amount of other resources. I was able to work my way through it, and I have no background in formal education past the high-school level, let alone a background in maths.
This is, in my opinion, required reading on the same level as SICP for people who are serious programmers - at least those with a weak math background.