The Art of Computer Programming
|
Art_of_Computer_Programming_-_Cover.gif
The Art of Computer Programming is a comprehensive monograph written by Donald Knuth which covers many kinds of programming algorithms and their analysis. Knuth began the project in 1962, which was originally planned to be one book. The first three volumes were published in rapid succession, starting with volume 1 in 1968, volume 2 in 1969, and volume 3 in 1973. Volume 4 is currently in preparation, the first installment of which was published in February 2005, with additional installments planned approximately twice per year. Originally, the work was planned as a single volume, but the plan changed to seven volumes after the publisher saw the size of the first handwritten draft. The plan for Volume 4 has since expanded to include Volumes 4A, 4B, 4C, and possibly 4D. In 1976, Knuth prepared a second edition of Volume 2, requiring it to be typeset again. But the style of type used in the first edition was no longer available. So in 1977 he decided to spend a few months working up something more suitable. Eight years later, he returned with TeX, which is currently used for all volumes.
- Volume 1 - Fundamental Algorithms
- Chapter 1 - Basic concepts
- Chapter 2 - Information structures
- Volume 2 - Seminumerical Algorithms
- Chapter 3 - Random numbers
- Chapter 4 - Arithmetic
- Volume 3 - Sorting and Searching
- Volume 4 - Combinatorial Algorithms, in preparation (fascicle 2 was published February 2005, and alpha-test versions of additional fascicles are downloadable from Knuth's page below).
- Volume 5 - Syntactic Algorithms, planned.
- Chapter 9 - Lexical scanning
- Chapter 10 - Parsing techniques
- Volume 6 - Theory of Context-Free Languages, planned.
- Volume 7 - Compiler Techniques, planned.
All examples in the books use a language called "MIX assembly language," which runs on the hypothetical MIX computer. (Currently, the MIX computer is being replaced by the MMIX computer, which is a RISC version). Some readers are chagrined at the use of assembly language, but Knuth considers this necessary because algorithms need a context to judge speed and memory usage. Fortunately, there are free MIX emulators available for download.
American Scientist has included this work among the best twelve physical-science monographs of the twentieth century.
The famous offer of a reward check for any errors found, and the correction of these errors in subsequent printings, has contributed to the highly polished and continued authoritative nature of the work, long after its first publication. Another characteristic of the volumes is the variation in the difficulty of the exercises. The level of difficulty ranges from "warm-up" exercises to unsolved research problems, giving any reader a challenge.
English editions
Current editions:
- Volume 1: Fundamental Algorithms. Third Edition (Reading, Massachusetts: Addison-Wesley, 1997), xx+650pp. ISBN 0-201-89683-4
- Volume 2: Seminumerical Algorithms. Third Edition (Reading, Massachusetts: Addison-Wesley, 1997), xiv+762pp. ISBN 0-201-89684-2
- Volume 3: Sorting and Searching. Second Edition (Reading, Massachusetts: Addison-Wesley, 1998), xiv+780pp.+foldout. ISBN 0-201-89685-0
- Volume 1, Fascicle 1: MMIX -- A RISC Computer for the New Millennium. (Addison-Wesley, February 14, 2005) ISBN 0-201-85392-2
- Volume 4, Fascicle 1: Boolean Techniques (in preparation).
- Volume 4, Fascicle 2: Generating all Tuples and Permutations, (Addison-Wesley, February 14, 2005) ISBN 0-201-85393-0
- Volume 4, Fascicle 3: Generating all Combinations and Partitions. (Addison-Wesley, August 5, 2005) ISBN 0-201-85394-9
- Volume 4, Fascicle 4: Generating all Trees (preview available).
External links
- Overview of topics (http://www-cs-faculty.stanford.edu/~knuth/taocp.html) (Knuth's personal homepage)cs:The Art of Computer Programming
de:The Art of Computer Programming The Art of Computer Programming ko:The Art of Computer Programming pl:The Art of Computer Programming ro:The Art of Computer Programming zh:计算机程序设计艺术