《DATA STRUCTURES WITH C++USING STL (第二版)》PDF下载

  • 购买积分:26 如何计算积分?
  • 作  者:[美]福特 [美]托普著
  • 出 版 社:清华大学出版社
  • 出版年份:2003
  • ISBN:
  • 页数:1036 页
图书介绍:

1 Introduction to Data Structures 1

1-1 WHAT IS THIS BOOK ABOUT? 2

Data Structures and Algorithms 5

1-2 ABSTRACT VIEW OF DATA STRUCTURES 5

The time24 ADT 6

1-3 AN ADT AS A CLASS 8

The C++ Class 8

Private and Public Sections 9

Encapsulation and Information Hiding 9

The time24 Class 9

1-4 IMPLEMENTING C++ CLASSES 13

Implementation of the time24 Class 14

1-5 DECLARING AND USING OBJECTS 18

Running a Program 18

1-6 IMPLEMENTING A CLASS WITH INLINE CODE 21

Compiler Use of Inline Code 22

1-7 APPLICATION PROGRAMMING INTERFACE(API) 23

Random Numbers 24

The randomNumberAPI 24

Application: The Game of Craps 26

1-8 STRINGS 28

The string Class 30

Additional String Functions and Operations 31

CHAPTER SUMMARY 36

CLASSES AND LIBRARIES IN THE CHAPTER 37

REVIEW EXERCISES 38

Answers to Review Exercises 40

WRITTEN EXERCISES 42

PROGRAMMING EXERCISES 48

PROGRAMMING PROJECTS 51

2 Object Design Techniques 53

2-1 SOFTWARE DESIGN 55

Request and Problem Analysis 56

Program Design 57

Designing the Calendar Class 58

Program Implementation 62

Implementing the Calendar Class 62

Program Testing and Debugging 64

Program Maintenance 68

2-2 HANDLING RUNTIME ERRORS 68

Terminate Program 69

Set a Flag 69

C++ Exceptions 70

2-3 OBJECT COMPOSITION 74

The timeCard Class 75

Implementing the timeCard Class 77

2-4 OPERATOR OVERLOADING 82

Operator Functions 85

Operator Overloading with Free Functions 86

Operator Overloading with Friend Functions 87

Overloading Stream I/O Operators 89

Member Function Overloading 94

CHAPTER SUMMARY 97

CLASSES AND LIBRARIES IN THE CHAPTER 98

REVIEW EXERCISES 99

Answers to Review Exercises 100

WRITTEN EXERCISES 102

PROGRAMMING EXERCISES 107

PROGRAMMING PROJECTS 108

3 Introduction to Algorithms 113

3-1 SELECTION SORT 115

Selection Sort Algorithm 116

3-2 SIMPLE SEARCH ALGORITHMS 120

Sequential Search 120

Binary Search 122

3-3 ANALYSIS OF ALGORITHMS 127

System/Memory Performance Criteria 128

Algorithm Performance Criteria: Running Time Analysis 128

Big-O Notation 131

Common Orders of Magnitude 133

3-4 ANALYZING THE SEARCH ALGORITHMS 135

Binary Search Running Time 135

Comparing Search Algorithms 136

3-5 MAKING ALGORITHMS GENERIC 139

Template Syntax 140

Runtime Template Expansion 142

Template-Based Searching Functions 144

3-6 THE CONCEPT OF RECURSION 146

Implementing Recursive Functions 148

How Recursion Works 149

Application: Multibase Output 152

3-7 PROBLEM SOLVING WITH RECURSION 155

Tower of Hanoi 155

Number Theory: The Greatest Common Divisor 159

Application of gcd - Rational Numbers 161

Evaluating Recursion 164

CHAPTER SUMMARY 168

CLASSES AND LIBRARIES IN THE CHAPTER 169

REVIEW EXERCISES 169

Answers to Review Exercises 172

WRITTEN EXERCISES 173

PROGRAMMING EXERCISES 179

PROGRAMMING PROJECT 182

4 The Vector Container 183

4-1 OVERVIEW OF STL CONTAINER CLASSES 184

4-2 TEMPLATE CLASSES 188

Constructing a Template Class 188

Declaring Template Class Objects 191

4-3 THE VECTOR CLASS 192

Introducing the Vector Container 195

The Vector API 200

4-4 VECTOR APPLICATIONS 202

Joining Vectors 203

The Insertion Sort 203

CHAPTER SUMMARY 208

CLASSES AND LIBRARIES IN THE CHAPTER 209

REVIEW EXERCISES 209

Answers to Review Exercises 211

WRITTEN EXERCISES 211

PROGRAMMING EXERCISES 216

PROGRAMMING PROJECT 217

5 Pointers and Dynamic Memory 219

5-1 C+ + POINTERS 221

Declaring Pointer Variables 222

Assigning Values to Pointers 222

Accessing Data with Pointers 224

Arrays And Pointers 225

Pointers and Class Types 227

5-2 DYNAMIC MEMORY 229

The Memory Allocation Operator new 229

Dynamic Array Allocation 231

The Memory Deallocation Operator delete 232

5-3 CLASSES USING DYNAMIC MEMORY 234

The Class dynamicClass 234

The Destructor 236

5-4 ASSIGNMENT AND INITIALIZATION 240

Assignment Issues 240

Overloading the Assignment Operator 242

The Pointer this 243

Initialization Issues 243

Creating a Copy Constructor 244

5-5 THE MINIVECTOR CLASS 247

Design of the miniVector Class 248

Reserving More Capacity 251

The miNiVector Constructor, Destructor, and Assignment 253

Adding and Removing Elements from a miNIVector Object 254

Overloading the Index Operator 258

5-6 THE MATRIX CLASS 260

Describing the Matrix Container 261

Implementing Matrix Functions 265

CHAPTER SUMMARY 266

CLASSES AND LIBRARIES IN THE CHAPTER 267

REVIEW EXERCISES 268

Answers to Review Exercises 270

WRITTEN EXERCISES 271

PROGRAMMING EXERCISES 277

PROGRAMMING PROJECT 279

6 The List Container and Iterators 281

6-1 THE LIST CONTAINER 282

The listADT 284

The listAPI 286

Application: A List Palindrome 288

6-2 ITERATORS 290

The Iterator Concept 290

Constant Iterators 294

The Sequential Search of a List 296

Application: Word Frequencies 298

6-3 GENERAL LIST INSERT AND ERASE OPERATIONS 302

Ordered Lists 305

Removing Duplicates 307

Splicing Two Lists 309

6-4 CASE STUDY:GRADUATION LISTS 310

Problem Analysis 310

Program Design 310

Program Implementation 312

CHAPTER SUMMARY 315

CLASSES AND LIBRARIES IN THE CHAPTER 316

REVIEW EXERCISES 316

Answers to Review Exercises 318

WRITTEN EXERCISES 319

PROGRAMMING EXERCISES 322

PROGRAMMING PROJECT 325

7 Stacks 327

7-1 THE STACK ADT 328

Multibase Output 332

Uncoupling Stack Elements 336

7-2 RECURSIVE CODE AND THE RUNTIME STACK 339

7-3 STACK IMPLEMENTATION 342

miniStack Class Implementation 345

Implementation of the STL stack Class (Optional) 346

7-4 POSTFIX EXPRESSIONS 347

Postfix Evaluation 349

The postfixEval Class 350

7-5 CASE STUDY: INFIX EXPRESSION EVALUATION 357

Infix Expression Attributes 358

Infix to Postfix Conversion: Algorithm Design 359

Infix to Postfix Conversion: Object Design 364

infix2Postftx Class Implementation 366

CHAPTER SUMMARY 372

CLASSES IN THE CHAPTER 373

REVIEW EXERCISES 373

Answers to Review Exercises 375

WRITTEN EXERCISES 377

PROGRAMMING EXERCISES 381

PROGRAMMING PROJECTS 382

8 Queues and Priority Queues 384

8-1 THE QUEUE ADT 386

Application: Scheduling Queue 388

8-2 THE RADIX SORT 390

Radix Sort Algorithm 391

8-3 IMPLEMENTING THE MINIQUEUE CLASS 395

Implementation of the STL queue Class (Optional) 398

8-4 CASE STUDY: TIME-DRIVEN SIMULATION 399

Simulation Design 400

Simulation Implementation 401

8-5 ARRAY BASED QUEUE IMPLEMENTATION 406

Designing the Bounded Queue 409

Implementing the Bounded Queue 411

8-6 PRIORITY QUEUES 412

Priority Queue ADT 413

Sorting with a Priority Queue 415

Company Support Services 417

CHAPTER SUMMARY 421

CLASSES AND LIBRARIES IN THE CHAPTER 422

REVIEW EXERCISES 423

Answers to Review Exercises 425

WRITTEN EXERCISES 426

PROGRAMMING EXERCISES 430

PROGRAMMING PROJECT 432

9 Linked Lists 436

9-1 LINKED LIST NODES 438

The node Class 439

Adding and Removing Nodes 442

9-2 BUILDING LINKED LISTS 443

Defining a Singly Linked List 443

Inserting at the Front of a Linked List 445

Erasing at the Front of a Linked List 447

Removing a Target Node 448

9-3 HANDLING THE BACK OF THE LIST 452

Designing a New Linked List Structure 453

9-4 IMPLEMENTING A LINKED QUEUE 455

The linkedQueue Class 456

Implementing the linkedQueue Class 457

9-5 DOUBLY LINKED LISTS 462

dnode Objects 463

Circular Doubly Linked Lists 466

9-6 UPDATING A DOUBLY LINKED LIST 468

The insert() Function 468

The erase() Function 470

9-7 THE JOSEPHUS PROBLEM 474

9-8 THE MINILIST CLASS 477

miniList Class Private Members 478

miniList Class Constructors and Destructor 479

Functions Dealing with the Ends of a List 480

miniList Iterators 481

The miniList Member Functions begin() and end() 485

The General List Insert Function 485

9-9 SELECTING A SEQUENCE CONTAINER 486

CHAPTER SUMMARY 487

CLASSES AND LIBRARIES IN THE CHAPTER 489

REVIEW EXERCISES 489

Answers to Review Exercises 493

WRITTEN EXERCISES 495

PROGRAMMING EXERCISES 498

PROGRAMMING PROJECT 500

10 Binary Trees 502

10-1 TREE STRUCTURES 504

Tree Terminology 505

Binary Trees 506

10-2 BINARY TREE NODES 510

Building a Binary Tree 511

10-3 BINARY TREE SCAN ALGORITHMS 514

Recursive Tree Traversals 514

Iterative Level-Order Scan 518

10-4 USING TREE SCAN ALGORITHMS 522

Computing the Leaf Count 522

Computing the Depths of a Tree 523

Copying a Binary Tree 526

Deleting Tree Nodes 529

Displaying a Binary Tree 530

10-5 BINARY SEARCH TREES 532

Introducing Binary Search Trees 533

Building a Binary Search Tree 534

Locating Data in a Binary Search Tree 535

Removing a Binary Search Tree Node 536

A Binary Search Tree Class 537

Access and Update Operations 538

10-6 USING BINARY SEARCH TREES 543

Application: Removing Duplicates 543

Application: The Video Store 545

10-7 IMPLEMENTING THE stree CLASS 551

The stree Class Data Members 553

Constructor, Destructor, and Assignment 554

Update Operations 554

Complexity of Binary Search Tree Operations 563

10-8 THE STREE ITERATOR (Optional) 563

Implementing the stree Iterator 565

CHAPTER SUMMARY 569

CLASSES AND LIBRARIES IN THE CHAPTER 571

REVIEW EXERCISES 571

Answers to Review Exercises 574

WRITTEN EXERCISES 576

PROGRAMMING EXERCISES 579

PROGRAMMING PROJECTS 581

11 Associative Containers 586

11-1 OVERVIEW OF ASSOCIATIVE CONTAINERS 587

Associative Container Categories 587

STL Associative Containers 590

Implementing Associative Containers 590

11-2 SETS 591

Displaying a Container Using Iterators 592

Set Access and Update Functions 593

A Simple Spelling Checker 596

Application: Sieve of Eratosthenes 600

Set Operations 603

Application: Updating Computer Accounts 606

11-3 MAPS 610

The Map Class Interface 610

Map Operations 613

Map Index Operator 614

Case Study: Concordance 618

11-4 MULTISETS 623

Application: Computer Software Products 625

11-5 IMPLEMENTING SETS AND MAPS 628

Implementing miniSet Operations 629

The miniMap Class 630

Implementing the miniMap Class 632

The miniMap Index Operator 633

CHAPTER SUMMARY 634

CLASSES AND LIBRARIES IN THE CHAPTER 635

REVIEW EXERCISES 635

Answers to Review Exercises 637

WRITTEN EXERCISES 638

PROGRAMMING EXERCISES 641

PROGRAMMING PROJECTS 643

12 Advanced Associative Structures 646

12-1 HASHING 649

Using a Hash Function 650

12-2 DESIGNING HASH FUNCTIONS 651

Function Objects 652

Illustrating Function Objects 653

Integer Hash Functions 656

String Hash Functions 658

A Custom Hash Function 659

12-3 DESIGNING HASH TABLES 659

Linear Probe Open Addressing 660

Chaining with Separate Lists 662

12-4 THE HASH CLASS 663

Application: Using a Hash Table 666

Hash Class Implementation 669

Implementing the Hash Iterators 672

Unordered Associative Containers 676

12-5 HASH TABLE PERFORMANCE 678

Comparing Search Algorithms 680

12-6 2-3-4 TREES 683

Inserting into a 2-3-4 Tree 686

Running Time for 2-3-4 Tree Operations 689

12-7 RED-BLACK TREES 690

Properties of a Red-Black Tree 692

Inserting Nodes in a Red-Black Tree 694

Building a Red-Black Tree 699

Search Running Time (Optional) 701

Erasing a Node in a Red-Black Tree 702

12-8 THE RBTREE CLASS 703

rbtree Class Private Section 707

Splitting a 4-node 707

The insert() Operation 709

CHAPTER SUMMARY 710

CLASSES AND LIBRARIES IN THE CHAPTER 711

REVIEW EXERCISES 712

Answers to Review Exercises 714

WRITTEN EXERCISES 716

PROGRAMMING EXERCISES 723

PROGRAMMING PROJECTS 725

13 Inheritance and Abstract Classes 727

13-1 INHERITANCE IN C++ 730

Declaring the Employee Hierarchy 731

Derived Class Constructor 734

Implementing Member Functions 736

13-2 THE GRAPHICS HIERARCHY 739

The circleShape Class 742

The Other Figure and Text Classes 744

Implementing the Polyshape Class 747

13-3 THE GRAPHICS SYSTEM 750

13-4 SAFE VECTORS 754

13-5 ORDERED LISTS 756

OrderedList Class Implementation 758

13-6 POLYMORPHISM AND VIRTUAL FUNCTIONS 759

Dynamic Binding 761

Application: Paying Employees with Polymorphism 763

Implementing Polymorphism in C++ 766

Virtual Functions And The Destructor 768

13-7 ABSTRACT CLASSES 771

An Abstract Class as an Interface 772

The Stack Interface 772

CHAPTER SUMMARY 773

CLASSES AND LIBRARIES IN THE CHAPTER 774

REVIEW EXERCISES 775

Answers to Review Exercises 778

WRITTEN EXERCISES 780

PROGRAMMING EXERCISES 786

PROGRAMMING PROJECT 789

14 Heaps Binary Files and Bit Sets 790

14-1 ARRAY BASED BINARY TREES 792

14-2 HEAPS 793

Inserting into a Heap 794

Deleting from a Heap 797

The Heap Sort 801

Heapifying a Vector 805

14-3 IMPLEMENTING A PRIORITY QUEUE 808

Implementing the miniPQ Class 809

14-4 BINARY FILES 811

File Structure 811

Direct File Access 812

Input and Output for Binary Files 813

Application: Bank Account Records 814

14-5 BITSETS 818

The bitVector Class 820

Implementing the bitVector Class 823

14-6 CASE STUDY: HUFFMAN COMPRESSION 826

Building the Huffinan Tree 830

Implementation of Huffman Compression 831

Huffman Decompression 840

CHAPTER SUMMARY 843

CLASSES AND LIBRARIES IN THE CHAPTER 844

REVIEW EXERCISES 845

Answers to Review Exercises 847

WRITTEN EXERCISES 849

PROGRAMMING EXERCISES 856

PROGRAMMING PROJECT 859

15 Recursive Algorithms 861

15-1 DIVIDE AND CONQUER ALGORITHMS 862

Building a Ruler 863

Mergesort 866

Quicksort 874

Comparison of Sorting Algorithms 884

Application: Finding Kth Largest Element 886

15-2 COMBINATORICS 889

Finding All Subsets 889

Listing Permutations 893

15-4 DYNAMIC PROGRAMMING 897

Top-Down Dynamic Programming 898

Application: Combinations 901

Bottom-Up Dynamic Programming 903

Knapsack Problem 904

15-4 BACKTRACKING: THE Eight-QUEENS PROBLEM 912

Problem Analysis 914

Program Design 915

Displaying a Chessboard 918

Illustrating the Eight-Queens Problem 920

CHAPTER SUMMARY 921

CLASSES AND LIBRARIES IN THE CHAPTER 923

REVIEW EXERCISES 923

Answers to Review Exercises 925

WRITTEN EXERCISES 929

PROGRAMMING EXERCISES 932

PROGRAMMING PROJECT 936

16 Graphs 939

16-1 GRAPH TERMINOLOGY 941

Directed Graphs 942

Weighted Graphs 943

16-2 THE GRAPH CLASS 944

Listing the Graph API 944

16-3 GRAPH CLASS DESIGN 951

Representing Vertex Information 951

The Vertex Map and Vlnfo List 953

Graph Class Declaration 957

Graph Class Implementation 958

16-4 GRAPH TRAVERSAL ALGORITHMS 962

Breadth-First Search 964

Depth-First Visit Algorithms 968

Depth-First Search 973

16-5 GRAPH TRAVERSAL APPLICATIONS 974

Acyclic Graphs 974

Topological Sort 977

Strong Components 981

16-6 GRAPH MINIMIZATION ALGORITHMS 985

Shortest Path Algorithm 986

Dijkstra’s Minimum Path Algorithm 991

Minimum Spanning Tree 998

CHAPTER SUMMARY 1006

CLASSES AND LIBRARIES IN THE CHAPTER 1007

REVIEW EXERCISES 1007

Answers to Review Exercises 1009

WRITTEN EXERCISES 1010

PROGRAMMING EXERCISES 1018

PROGRAMMING PROJECT 1019

Index 1021