Skip to main content
  • Textbook
  • © 2014

Practical Analysis of Algorithms

  • Provides highly detailed yet easy to understand explanations and proofs
  • Presents numerous practical examples throughout the text
  • Introduces the fundamental mathematics required, described from the point of view of a programmer
  • Includes supplementary material: sn.pub/extras
  • Request lecturer material: sn.pub/lecturer-material

Part of the book series: Undergraduate Topics in Computer Science (UTICS)

Buy it now

Buying options

eBook USD 44.99
Price excludes VAT (USA)
  • Available as EPUB and PDF
  • Read on any device
  • Instant download
  • Own it forever
Softcover Book USD 59.99
Price excludes VAT (USA)
  • Compact, lightweight edition
  • Dispatched in 3 to 5 business days
  • Free shipping worldwide - see info

Tax calculation will be finalised at checkout

Other ways to access

This is a preview of subscription content, log in via an institution to check for access.

Table of contents (8 chapters)

  1. Front Matter

    Pages i-xii
  2. Introduction

    • Dana Vrajitoru, William Knight
    Pages 1-7
  3. Mathematical Preliminaries

    • Dana Vrajitoru, William Knight
    Pages 9-62
  4. Fundamental Notations in Analysis of Algorithms

    • Dana Vrajitoru, William Knight
    Pages 63-94
  5. Recurrence Relations

    • Dana Vrajitoru, William Knight
    Pages 95-167
  6. Deterministic Analysis of Algorithms

    • Dana Vrajitoru, William Knight
    Pages 169-293
  7. Algorithms and Probabilities

    • Dana Vrajitoru, William Knight
    Pages 295-360
  8. Finite Graph Algorithms

    • Dana Vrajitoru, William Knight
    Pages 361-452
  9. Appendix: Probability Theory

    • Dana Vrajitoru, William Knight
    Pages 453-462
  10. Back Matter

    Pages 463-466

About this book

This book introduces the essential concepts of algorithm analysis required by core undergraduate and graduate computer science courses, in addition to providing a review of the fundamental mathematical notions necessary to understand these concepts. Features: includes numerous fully-worked examples and step-by-step proofs, assuming no strong mathematical background; describes the foundation of the analysis of algorithms theory in terms of the big-Oh, Omega, and Theta notations; examines recurrence relations; discusses the concepts of basic operation, traditional loop counting, and best case and worst case complexities; reviews various algorithms of a probabilistic nature, and uses elements of probability theory to compute the average complexity of algorithms such as Quicksort; introduces a variety of classical finite graph algorithms, together with an analysis of their complexity; provides an appendix on probability theory, reviewing the major definitions and theorems used in the book.

Reviews

“This textbook is a practical approach to the analysis of algorithms from a programmer’s perspective. … This book therefore does play an important role for educating programmers on how to analyze the runtime requirements of their algorithms. … The authors are in essence talking to readers when presenting the material and take a step-by-step approach when presenting the mathematical proofs. … A one-semester course on the analysis of algorithms can be crafted based on the chapters of this text.” (R. Goldberg, Computing Reviews, March, 2015)

“Vrajitoru and Knight (both, Indiana Univ.) cover standard algorithmic problems from sorting to graph theory. The authors provide ready-to-run C++ programs for many of their algorithms. It is clear from the exercises and examples that this book's content has been used in teaching undergraduates for a number of years. … Summing Up: Recommended. Lower- and upper-division undergraduates and faculty.” (P. Cull, Choice, Vol. 52 (10), June, 2015)

“The book is dedicated to an old, important and complex topic in computer science. … The multiple exercises in each section invite the readers to a deeper exploration of the subjects. The formalized style of the book is expected to attract especially young students introduced already to mathematical formalisms. The material can be used as a textbook for undergraduate courses in computer science.” (Dana Petcu, zbMATH, Vol. 1303, 2015)

Authors and Affiliations

  • Indiana University, South Bend, USA

    Dana Vrajitoru, William Knight

About the authors

Dr. Dana Vrajitoru is an Associate Professor of Computer Science at Indiana University South Bend, IN, USA. Dr. William Knight is an Emeritus Associate Professor at the same institution.

Bibliographic Information

Buy it now

Buying options

eBook USD 44.99
Price excludes VAT (USA)
  • Available as EPUB and PDF
  • Read on any device
  • Instant download
  • Own it forever
Softcover Book USD 59.99
Price excludes VAT (USA)
  • Compact, lightweight edition
  • Dispatched in 3 to 5 business days
  • Free shipping worldwide - see info

Tax calculation will be finalised at checkout

Other ways to access