Our systems are now restored following recent technical disruption, and we’re working hard to catch up on publishing. We apologise for the inconvenience caused. Find out more

Recommended product

Popular links

Popular links


How to Think About Algorithms

How to Think About Algorithms

How to Think About Algorithms

Jeff Edmonds , York University, Toronto
No date available
Adobe eBook Reader
9780511410451
Adobe eBook Reader

    This textbook, for second- or third-year students of computer science, presents insights, notations, and analogies to help them describe and think about algorithms like an expert, without grinding through lots of formal proof. Solutions to many problems are provided to let students check their progress, while class-tested PowerPoint slides are on the web for anyone running the course. By looking at both the big picture and easy step-by-step methods for developing algorithms, the author guides students around the common pitfalls. He stresses paradigms such as loop invariants and recursion to unify a huge range of algorithms into a few meta-algorithms. The book fosters a deeper understanding of how and why each algorithm works. These insights are presented in a careful and clear way, helping students to think abstractly and preparing them for creating their own innovative ways to solve problems.

    • Includes lots of exercises, with selected solutions in the text; PowerPoint slides for instructors available from the web
    • Presents the big picture and step-by-step methods for developing algorithms, while avoiding common pitfalls
    • Appendices give background on big-O notation, logic, asymptotics, and other mathematical tools

    Reviews & endorsements

    'Reading this is like sitting at the feet of the master: it leads an apprentice from knowing how to program to understanding deep principles of algorithms.' Harold Thimbleby, The Times Higher Education Supplement

    '… a great book to learn how to design and create new algorithms … a good book that the reader will appreciate in the first and subsequent reads, and it will make better developers and programmers.' Journal of Functional Programming

    See more reviews

    Product details

    No date available
    Paperback
    9780521614108
    472 pages
    233 × 177 × 24 mm
    0.75kg
    156 b/w illus. 24 tables 203 exercises

    Table of Contents

    • Part I. Iterative Algorithms and Loop Invariants:
    • 1. Measures of progress and loop invariants
    • 2. Examples using more of the input loop invariant
    • 3. Abstract data types
    • 4. Narrowing the search space: binary search
    • 5. Iterative sorting algorithms
    • 6. Euclid's GCD algorithm
    • 7. The loop invariant for lower bounds
    • Part II. Recursion:
    • 8. Abstractions, techniques, and theory
    • 9. Some simple examples of recursive algorithms
    • 10. Recursion on trees
    • 11. Recursive images
    • 12. Parsing with context-free grammars
    • Part III. Optimization Problems:
    • 13. Definition of optimization problems
    • 14. Graph search algorithms
    • 15. Network flows and linear programming
    • 16. Greedy algorithms
    • 17. Recursive backtracking
    • 18. Dynamic programming algorithms
    • 19. Examples of dynamic programming
    • 20. Reductions and NP-completeness
    • 21. Randomized algorithms
    • Part IV. Appendix:
    • 22. Existential and universal quantifiers
    • 23. Time complexity
    • 24. Logarithms and exponentials
    • 25. Asymptotic growth
    • 26. Adding made easy approximations
    • 27. Recurrence relations
    • 28. A formal proof of correctness
    • Part V. Exercise Solutions.
    Resources for
    Type
    Errata
    Size: 6.95 KB
    Type: application/pdf
    Math
    Size: 609.61 KB
    Type: application/zip
    Matrix Multiplication and All Pairs figures
    Size: 144.16 KB
    Type: application/zip
    Lowerbounds
    Size: 251.57 KB
    Type: application/zip
    Recursion
    Size: 1.86 MB
    Type: application/zip
    Network Flow
    Size: 802.75 KB
    Type: application/zip
    Greedy
    Size: 3.19 MB
    Type: application/zip
    Dynamic Programming
    Size: 1.74 MB
    Type: application/zip
    Searching in a Graph
    Size: 1.05 MB
    Type: application/zip
    Solutions
    Size: 361.37 KB
    Type: application/pdf
    Sign inThis resource is locked and access is given only to lecturers adopting the textbook for their class. We need to enforce this strictly so that solutions are not made available to students. To gain access to locked resources you either need first to sign in or register for an account.
    GCD
    Size: 73.48 KB
    Type: application/zip
    Author's website
      Author
    • Jeff Edmonds , York University, Toronto

      Jeff Edmonds received his Ph.D. in 1992 at University of Toronto in theoretical computer science. His thesis proved that certain computation problems require a given amount of time and space. He did his postdoctorate work at the ICSI in Berkeley on secure multi-media data transmission and in 1995 became an Associate Professor in the Department of Computer Science at York University, Canada. He has taught their algorithms course thirteen times to date. He has worked extensively at IIT Mumbai, India, and University of California San Diego. He is well published in the top theoretical computer science journals in topics including complexity theory, scheduling, proof systems, probability theory, combinatorics, and, of course, algorithms.