
Algorithms and Data Structures
The Basic Toolbox
By: Kurt Mehlhorn, Peter Sanders
Hardcover | 23 June 2008 | Edition Number 2008
At a Glance
316 Pages
16.7 x 24.2 x 2.2
Hardcover
$99.00
or 4 interest-free payments of $24.75 with
orShips in 5 to 7 business days
Algorithms are at the heart of every nontrivial computer application, and algorithmics is a modern and active area of computer science. Every computer scientist and every professional programmer should know about the basic algorithmic toolbox: structures that allow efficient organization and retrieval of data, frequently used algorithms, and basic techniques for modeling, understanding and solving algorithmic problems.
This book is a concise introduction addressed to students and professionals familiar with programming and basic mathematical language. Individual chapters cover arrays and linked lists, hash tables and associative arrays, sorting and selection, priority queues, sorted sequences, graph representation, graph traversal, shortest paths, minimum spanning trees, and optimization. The algorithms are presented in a modern way, with explicitly formulated invariants, and comment on recent trends such as algorithm engineering, memory hierarchies, algorithm libraries and certifying algorithms. The authors use pictures, words and high-level pseudocode to explain the algorithms, and then they present more detail on efficient implementations using real programming languages like C++ and Java.
The authors have extensive experience teaching these subjects to undergraduates and graduates, and they offer a clear presentation, with examples, pictures, informal explanations, exercises, and some linkage to the real world. Most chapters have the same basic structure: a motivation for the problem, comments on the most important applications, and then simple solutions presented as informally as possible and as formally as necessary. For the more advanced issues, this approach leads to a more mathematical treatment, including some theorems and proofs. Finally, each chapter concludes with a section on further findings, providing views on the state of research, generalizations and advanced solutions.
Industry Reviews
| Appetizer: Integer Arithmetics | p. 1 |
| Addition | p. 2 |
| Multiplication: The School Method | p. 3 |
| Result Checking | p. 6 |
| A Recursive Version of the School Method | p. 7 |
| Karatsuba Multiplication | p. 9 |
| Algorithm Engineering | p. 11 |
| The Programs | p. 13 |
| Proofs of Lemma 1.5 and Theorem 1.7 | p. 16 |
| Implementation Notes | p. 17 |
| Historical Notes and Further Findings | p. 18 |
| Introduction | p. 19 |
| Asymptotic Notation | p. 20 |
| The Machine Model | p. 23 |
| Pseudocode | p. 26 |
| Designing Correct Algorithms and Programs | p. 31 |
| An Example - Binary Search | p. 34 |
| Basic Algorithm Analysis | p. 36 |
| Average-Case Analysis | p. 41 |
| Randomized Algorithms | p. 45 |
| Graphs | p. 49 |
| P and NP | p. 53 |
| Implementation Notes | p. 56 |
| Historical Notes and Further Findings | p. 57 |
| Representing Sequences by Arrays and Linked Lists | p. 59 |
| Linked Lists | p. 60 |
| Unbounded Arrays | p. 66 |
| *Amortized Analysis | p. 71 |
| Stacks and Queues | p. 74 |
| Lists Versus Arrays | p. 77 |
| Implementation Notes | p. 78 |
| Historical Notes and Further Findings | p. 79 |
| Hash Tables and Associative Arrays | p. 81 |
| Hashing with Chaining | p. 83 |
| Universal Hashing | p. 85 |
| Hashing with Linear Probing | p. 90 |
| Chaining Versus Linear Probing | p. 92 |
| *Perfect Hashing | p. 92 |
| Implementation Notes | p. 95 |
| Historical Notes and Further Findings | p. 97 |
| Sorting and Selection | p. 99 |
| Simple Sorters | p. 101 |
| Mergesort - an O(n log n) Sorting Algorithm | p. 103 |
| A Lower Bound | p. 106 |
| Quicksort | p. 108 |
| Selection | p. 114 |
| Breaking the Lower Bound | p. 116 |
| *External Sorting | p. 118 |
| Implementation Notes | p. 122 |
| Historical Notes and Further Findings | p. 124 |
| Priority Queues | p. 127 |
| Binary Heaps | p. 129 |
| Addressable Priority Queues | p. 133 |
| *External Memory | p. 139 |
| Implementation Notes | p. 141 |
| Historical Notes and Further Findings | p. 142 |
| Sorted Sequences | p. 145 |
| Binary Search Trees | p. 147 |
| (a, b)-Trees and Red-Black Trees | p. 149 |
| More Operations | p. 156 |
| Amortized Analysis of Update Operations | p. 158 |
| Augmented Search Trees | p. 160 |
| Implementation Notes | p. 162 |
| Historical Notes and Further Findings | p. 164 |
| Graph Representation | p. 167 |
| Unordered Edge Sequences | p. 168 |
| Adjacency Arrays - Static Graphs | p. 168 |
| Adjacency Lists-Dynamic Graphs | p. 170 |
| The Adjacency Matrix Representation | p. 171 |
| Implicit Representations | p. 172 |
| Implementation Notes | p. 172 |
| Historical Notes and Further Findings | p. 174 |
| Graph Traversal | p. 175 |
| Breadth-First Search | p. 176 |
| Depth-First Search | p. 178 |
| Implementation Notes | p. 188 |
| Historical Notes and Further Findings | p. 189 |
| Shortest Paths | p. 191 |
| From Basic Concepts to a Generic Algorithm | p. 192 |
| Directed Acyclic Graphs | p. 195 |
| Nonnegative Edge Costs (Dijkstra's Algorithm) | p. 196 |
| *Average-Case Analysis of Dijkstra's Algorithm | p. 199 |
| Monotone Integer Priority Queues | p. 201 |
| Arbitrary Edge Costs (Bellman-Ford Algorithm) | p. 206 |
| All-Pairs Shortest Paths and Node Potentials | p. 207 |
| Shortest-Path Queries | p. 209 |
| Implementation Notes | p. 213 |
| Historical Notes and Further Findings | p. 214 |
| Minimum Spanning Trees | p. 217 |
| Cut and Cycle Properties | p. 218 |
| The Jarník-R-im Algorithm | p. 219 |
| Kruskal's Algorithm | p. 221 |
| The Union-Find Data Structure | p. 222 |
| *External Memory | p. 225 |
| Applications | p. 228 |
| Implementation Notes | p. 231 |
| Historical Notes and Further Findings | p. 231 |
| Generic Approaches to Optimization | p. 233 |
| Linear Programming - a Black-Box Solver | p. 234 |
| Greedy Algorithms - Never Look Back | p. 239 |
| Dynamic Programming - Building It Piece by Piece | p. 243 |
| Systematic Search - When in Doubt, Use Brute Force | p. 246 |
| Local Search - Think Globally, Act Locally | p. 249 |
| Evolutionary Algorithms | p. 259 |
| Implementation Notes | p. 261 |
| Historical Notes and Further Findings | p. 262 |
| Appendix | p. 263 |
| MathematicalSymbols | p. 263 |
| Mathematical Concepts | p. 264 |
| Basic Probability Theory | p. 266 |
| UsefulFormulae | p. 269 |
| References | p. 273 |
| Index | p. 285 |
| Table of Contents provided by Publisher. All Rights Reserved. |
ISBN: 9783540779773
ISBN-10: 3540779779
Published: 23rd June 2008
Format: Hardcover
Number of Pages: 316
Audience: Professional and Scholarly
Publisher: Springer Nature B.V.
Country of Publication: GB
Edition Number: 2008
Dimensions (cm): 16.7 x 24.2 x 2.2
Weight (kg): 0.6
Shipping
| Standard Shipping | Express Shipping | |
|---|---|---|
| Metro postcodes: | $9.99 | $14.95 |
| Regional postcodes: | $9.99 | $14.95 |
| Rural postcodes: | $9.99 | $14.95 |
Orders over $79.00 qualify for free shipping.
How to return your order
At Booktopia, we offer hassle-free returns in accordance with our returns policy. If you wish to return an item, please get in touch with Booktopia Customer Care.
Additional postage charges may be applicable.
Defective items
If there is a problem with any of the items received for your order then the Booktopia Customer Care team is ready to assist you.
For more info please visit our Help Centre.

























