Đang chuẩn bị nút TẢI XUỐNG, xin hãy chờ
Tải xuống
A comprehensive treatment focusing on the creation of efficient data structures and algorithms, this text explains how to select or design the data structure best suited to specific problems. It uses C++ as the programming language and is suitable for second-year data structure courses and computer science courses in algorithmic analysis. | Data Structures and Algorithm Analysis Edition 3.2 C Version Clifford A. Shaffer Department of Computer Science Virginia Tech Blacksburg VA 24061 January 2 2012 Update 3.2.0.3 For a list of changes see http people.cs.vt.edu shaffer Book errata.html Copyright 2009-2012 by Clifford A. Shaffer. This document is made freely available in PDF form for educational and other non-commercial use. You may make copies of this file and redistribute in electronic form without charge. You may extract portions of this document provided that the front page including the title author and this notice are included. Any commercial use of this document requires the written consent of the author. The author can be reached at shaffer@cs.vt.edu. If you wish to have a printed version of this document print copies are published by Dover Publications see http store.doverpublications.com 04 8 64 8582x.html . Further information about this text is available at http people.cs.vt.edu shaffer Book . Contents Preface xiii I Preliminaries 1 1 Data Structures and Algorithms 3 1.1 A Philosophy of Data Structures 4 1.1.1 The Need for Data Structures 4 1.1.2 Costs and Benefits 6 1.2 Abstract Data Types and Data Structures 8 1.3 Design Patterns 12 1.3.1 Flyweight 13 1.3.2 Visitor 13 1.3.3 Composite 14 1.3.4 Strategy 15 1.4 Problems Algorithms and Programs 16 1.5 Further Reading 18 1.6 Exercises 20 2 Mathematical Preliminaries 25 2.1 Sets and Relations 25 2.2 Miscellaneous Notation 29 2.3 Logarithms 31 2.4 Summations and Recurrences 32 2.5 Recursion 36 2.6 Mathematical Proof Techniques 38 iii iv Contents 2.6.1 Direct Proof 39 2.6.2 Proof by Contradiction 39 2.6.3 Proof by Mathematical Induction 40 2.7 Estimation 46 2.8 Further Reading 47 2.9 Exercises 48 3 Algorithm Analysis 55 3.1 Introduction 55 3.2 Best Worst and Average Cases 61 3.3 A Faster Computer or a Faster Algorithm 62 3.4 Asymptotic Analysis 65 3.4.1 Upper Bounds 65 3.4.2 Lower Bounds 67 3.4.3 0 Notation 68 3.4.4 Simplifying Rules 69 3.4.5 .