推荐理由
无数读者都曾谈起过Knuth专著对他们个人产生的巨大影响。科学家们惊讶于他精美、雅致的问题分析方式,而普通程序员则利用他提供的方案成功地解决日常工作中遇到的问题。书的恢宏、透彻、精确与幽默赢得了所有人的尊敬。
Knuth专著伴我在学习和生活中度过了无数欢乐时光。我在车里,在餐馆里,在家里……甚至在我儿子小联赛的间隙都忘不了带上它们,一有空就捧出来阅读。
——Charles Long
这套书本来作为参考之用,但后来人们发现,把这套书的每一卷从头读到尾不仅是可能的,而且也是非常有意义的。一位中国的程序员甚至把他的阅读经历比做吟诗。
如果你是一名真正优秀的程序员……读Knuth的《计算机程序设计艺术》。如果你读懂整套书,请给我发一份简历。
——Bill Gates
不管基础如何,只要你想认真地编写任何计算机程序,你都有必要把这套书的任何一卷抱回家,以便在你学习和工作的时候随时翻阅。
要是有一个问题难到要把《计算机程序设计艺术》请下书架,那将是一种莫大的荣幸。我发现,这套书仅仅是开卷展读,就可能会对计算机产生巨大的影响。
——Jonathan Laventhol
内容简介
这是对第3卷的头一次修订,不仅是对经典计算机排序和查找技术的最全面介绍,而且还对第1卷中的数据结构处理技术作了进一步的扩充,通盘考虑了将大小型数据库和内外存储器。它遴选了一些经过反复检验的计算机方法,并对其效率做了定量分析。第3卷的突出特点是对“最优排序”一节作了修订,对排列论原理与通用散列法作了全新讨论。
本文作者
Donald.E.Knuth(唐纳德.E.克努特,中文名高德纳)是算法和程序设计技术的先驱者,是计算机排版系统TEX和METAFONT的发明者,他因这些成就和大量创造性的影响深远的著作(19部书和160篇论文)而誉满全球。作为斯坦福大学计算机程序设计艺术的荣誉退休教授,他当前正全神贯注于完成其关于计算机科学的史诗性的七卷集。这一伟大工程在1962年他还是加利福尼亚理工学院的研究生时就开始了。Knuth教授获得了许多奖项和荣誉,包括美国计算机协会图灵奖(ACM Turing Award),美国前总统卡特授予的科学金奖(Medal of Science),美国数学学会斯蒂尔奖(AMS Steele Prize),以及1996年11月由于发明先进技术而荣获的备受推崇的京都奖(Kyoto Prize)。Knuth教授现与其妻Jill生活于斯坦福校园内。
访问Knuth教授的个人主页,可以获得有关本书及本系列其他未出版图书的更多信息:
www-cs-faculty.stanford.edu/~knuth
目录
Chapter 5 Sorting
5.1 Combinatorial Properties of Permutations
5.1.1 Inversions
5.1.2 Permutations of a Multiset
5.1.3 Runs
5.1.4 Tableaux and Involutions
5.2 Internal sorting
5.2.1 Sorting by Insertion
5.2.2 Sorting by Exchanging
5.2.3 Sorting by Selection
5.2.4 Sorting by Merging
5.2.5 Sorting by Distribution
5.3 Optimum Sorting
5.3.1 Minimum-Comparison Sorting
5.3.2 Minimum-Comparison Merging
5.3.3 Minimum-Comparison Selection
5.3.4 Networks for Sorting
5.4 External Sorting
5.4.1 Multiway Merging and Replacement Selection
5.4.2 The Polyphase Merge
5.4.3 The Cascade Merge
5.4.4 Reading Tape Backwards
5.4.5 The Oscillating Sort
5.4.6 Practical Considerations for Tape Merging
5.4.7 External Radix Sorting
5.4.8 Two-Tape Sorting
5.4.9 Disks and Drums
5.5 Summary, History, and Bibliography
Chapter 6 Searching
6.1 Sequential Searching
6.2 Searching by Comparison of Keys
6.2.1 Searching an Ordered Table
6.2.2 Binary Tree Searching
6.2.3 Balanced Trees
6.2.4 Multiway Trees
6.3 Digital Searching
6.4 Hashing
6.5 Retrieval on Secondary Keys
Answers to Exercises
Appendix A: Tables of Numerical Quantities
1 Fundamental Constants (decimal)
2 Fundamental Constants (octal)
3 Harmonic Numbers, Bernoulli Numbers, Fibonacci Numbers
Appendix B:Index to Notations
Index and Glossary