《数据结构与程序设计 C 语言描述 第2版 英文》PDF下载

  • 购买积分:19 如何计算积分?
  • 作  者:(美)鲁克泽(Kruse,R.)等著
  • 出 版 社:北京:清华大学出版社
  • 出版年份:1998
  • ISBN:7302029431
  • 页数:671 页
图书介绍:内容简介本书强调问题的描述和程序的分析、设计、测试、验证以及程序正确性,将深思熟虑的开发的基本思路融于具体的程序设计之中。书中介绍了程序设计原理和软件工程知识以及如何将这些原理和知识运用于程序(算法)设计,使用大量实例介绍了几种主要数据结构:栈、表、树、图及主要算法如递归、查找、排序、检索等,在介绍过程中注重运用程序设计的先进思想和软件工程的解决方法。书中给出的实例很有代表性,能覆盖大量程序设计原理。数据抽象是贯穿全书的思想。本书还包括了如倾斜树、红黑树等很多新的内容。最后,以一个完整的实例详细讨论了用递归、树、栈等手段解决具体问题。附录中介绍了一些常用数学算法及如何消除递归,并对C语言作了简单小结。本书适合于计算机专业本科生作为学习数据结构的教材或辅助教材。

CHAPTER 1

Programming Principles 1

1.1 Introduction 2

CHAPTER 2

CHAPTER 3

1.2 The Game of Life 4

1.2.1 Rules for the Gane of Life 4

CHAPTER 4

1.2.2 Examples 5

CHAPTER 5

1.2.3 The Solution 6

CHAPTER 6

1.2.4 Life:The Main Program 7

CHAPTER 7

CHAPTER 8

CHAPTER 9

1.3.1 Names 10

1.3 Programming Style 10

CHAPTER 10

Contents 11

PREFACE 11

CHAPTER 11

Synopsis 12

1.3.2 Documentation and Format 12

CHAPTER 12

Changes in the Second Edition 13

Course Structure 14

1.3.3 Refinement and Modularity 14

Book Production 15

Acknowledgments 16

1.4 Coding,Testing,and 19

Further Refinement 19

1.4.1 Stubs 19

1.4.2 Counting Neighbors 20

1.4.3 Input and Output 21

1.4.4 Drivers 24

1.4.5 Program Tracing 25

1.4.6 Principles of Program Testing 26

Pointers and Pitfalls 30

Review Questions 32

References for Further Study 32

C 32

Programming Principles 33

The Game of Life 33

Introduction to 34

Software Engineering 34

2.1 Program Maintenance 35

2.1.1 Review of the Life Program 35

2.1.2 A Fresh Start and a New Method forLife 37

2.2 Algorithm Development: 40

2.2.1 Lists:Specifications for a 40

Data Structure 40

A Second Version of Life 40

2.2.2 The Main Program 45

2.2.3 Information Hiding 47

Subprograms 48

2.2.4 Refinement:Development of the 48

2.2.5 Verification of Algorithms 50

2.3 Coding 55

2.3.1 The List Functions 55

2.3.2 Error Processing 56

2.3.3 Demonstration and Testing 57

2.4 Coding the Life Functions 62

2.5 Program Analysis and Comparison 66

2.6 Conclusions and Preview 68

2.6.1 The Game of Life 68

2.6.2 Program Design 70

2.6.3 C 73

Pointers and Pitfalls 75

Review Questions 75

References for Further Study 76

Stacks and Recursion 77

3.1 Stacks 78

3.1.1 Introduction 78

3.1 2 First Example:Reversing a Line 79

3 1 3 Information Hiding 80

3.1.4 Specifications for a Stack 81

3 1.5 Implementation of Stacks 83

31.6 Linked Stacks 85

3.2 Introduction to Recursion 91

3.2.1 Stack Frames for Subprograms 91

3.2 2 Tree of Subprogram Calls 91

3.2.3 Factorials:A Recursive Definition 93

3.2 4 Divide and Conquer: 95

The Towers of Hanoi 95

3.3 Backtracking:Postponing the Work 101

3.3.2 Example:Four Queens 102

3.3.1 Solving the Eight-Queens Puzzle 102

3.3.3 Backtracking 103

Choosing the Data Structures 104

3.3.4 Refinement: 104

3.3 5 Analysis of Backtracking 107

3.4.1 Designing Recursive Algorithms 110

3.4 Principles of Recursion 110

3 4.2 How Recursion Works 111

3.4.3 Tail Recursion 115

3.4.4 When Not to Use Recursion 116

3 4.5 Guidelines and Conclusions 120

Pointers and Pitfalls 122

Review Questions 124

References for Further Study 124

Queues and Linked Lists 126

4.1 Definitions 127

4.2 Implementations of Queues 131

4.3 Circular Queues in C 135

4.4 Application of Queues:Simulation 139

4.4.1 Introduction 139

4.4.2 Sirmulation of an Airport 140

4.4.3 The Main Program 142

4.4.4 Steps of the Simulation 144

4.4.5 Pseudo-Random Numbers 147

4.4.6 Sample Results 149

4.5 Pointers and Linked Lists 152

4.5.1 Introduction and Survey 152

4.5.2 PointersandDynamicMemoryinC 155

4.5.3 The Basics of Linked Lists 159

4.6 Linked Queues 161

4.71 PurposeoftheProject 166

Polynomial Arithmetic 166

4.7 Application: 166

4.7.2 The Main Program 166

Implementation 171

4.7.3 Data Structures and Their 171

4.7.4 Reading and Writing Polynomials 172

4.7.5 Addition of Polynomials 174

4.7.6 Completing the Project 176

4.8.1 Introduction 179

Their Implementations 179

4.8 Abstract Data Types and 179

4.8.2 General Definitions 180

4.8.3 Refinement of Data Specification 183

Review Questions 185

Pointers and Pitfalls 185

References for Further Study 186

General Lists 187

5.1 List Specifications 188

5.2.1 Contiguous Implementation 190

5.2 Implementation of Lists 190

5.2.2 Simply Linked Implementation 191

5.2.3 Variation:Keeping the CurrentPosition 195

5.2.4 Doubly Linked Lists 197

5.2.5 Comparison of Implementations 200

5.3 Strings 202

5.4 Application:A Text Editor 205

5 4.1 Specifications 205

5.4.2 Implementation 207

5.5 Linked Lists in Atrays 214

5.6 Generating Permutations 223

Pointers and Pitfalls 228

Review Questions 229

References for Further Study 230

Searching 231

Introduction and Notation 232

6.1 Searching: 232

6.2 Sequential Search 235

6.3.1 Introducton and Specification 241

6.3 Coatrooms:A Project 241

Programs 244

6 3.2 Demonstration and Testing 244

6.4 Binary Search 248

6.4.1 Algorithm Development 249

6.4.2 The Forgetful Version 249

6.4.3 Recognizing Equality 252

6.5 Comparison Trees 254

6.5.1 Analysisfor n=10 255

6.5.2 Generalizaton 258

6.5.3 Comparison of Methods 261

6.5.4 A General Relationship 263

6.6 Lower Bounds 264

6.7.1 Introducton 269

6.7 Asymptotics 269

6.7 2 The Big-O Notation 270

6.7.3 Imprecision of the Big-O Notation 273

6.7.4 Ordering of Cornmon Functions 274

Pointers and Pitfalls 275

Review Questions 276

References for Further Study 276

Sorting 278

7.1 Introduction and Notation 279

7.2 Insertion Sort 280

7 2.1 Ordered Lists 280

7 2.2 Sorting by Insertion 281

7.2.3 Linked Version 283

7 2.4 Analysis 285

7.3 Selection Sort 288

7.3.1 The Algorithm 289

7.3.2 Contiguous Implementation 290

7.3.4 Comparisons 291

7.3.3 Analysis 291

7.4 Shell Sort 293

7.5 Lower Bounds 295

7.6 Divide-and-Conquer Sorting 298

7.6.1 The Main Ideas 298

7.6.2 AnExample 299

7.7 Mergesort for Linked Lists 304

7.7.1 The Functions 304

7.7.2 Analysis of Mergesort 306

7.8 Quicksort for Contiguous Lists 311

7.8.1 The Main Function 311

7.8.2 Partitioning the List 312

7.8.3 Analysis of Quicksort 314

7.8 4 Average-Case Anialysis of Quicksort 316

7.8 5 Comparison with Mergesort 318

7.9 Heaps and Heapsort 321

7.9.1 Two-Way Trees as Lists 322

7.9.2 Heapsort 323

7.9.3 Analysis of Heapsort 327

7.9.4 Priority Queues 328

7.10 Review:Comparison of Methods 330

Pointers and Pitfalls 333

Review Questions 334

References for Further Study 334

Tables and Information Retrieval 336

8.1 Introduction: 337

Breaking the lgn Barrier 337

8.2 Rectangular Arrays 337

8.3 Tables of Various Shapes 340

8.3.1 Triangular Tables 340

8.3.2 Jagged Tables 342

8.3.3 Inverted Tables 342

8.4 Tables:A New Abstract Data Type 345

8.5 Application:Radix Sort 348

8.5.1 The Idea 348

8.5 2 Implementation 349

8.5 3 Analysis 352

8.6 Hashing 353

8.6.1 Sparse Tables 353

8 6.2 Choosing a Hash Function 355

8.6 3 Collision Resolution with 357

Open Addressing 357

8.6.4 Collision Resolution by Chaining 362

8.7 Analysis of Hashing 367

8.8 Conclusions: 373

Comparison of Methods 373

8.9.2 Specification of Data Structures 374

The Life Game Revisited 374

8.9.1 Choice of Algorithm 374

8.9 Application: 374

8 9.3 The Main Program 376

8.9.4 Functions 377

Pointers and Pitfalls 380

Review Questions 381

References for Further Study 382

Binary Trees 383

9.1 Introduction to Binary Trees 384

9.1.1 Definitions 384

9.1.2 Traversal of Binary Trees 386

Binary Trees 391

9.1.3 Linked Implementation of 391

9.2 Binary Search Tees 396

9.2.1 Ordered Lists and Implementations 397

9.2.2 Treesearch 398

9.2.3 Insertion into a Binary Search Tree 401

9.2.4 Treesort 404

9.2.5 Deletion from a Binary Search Tree 406

9.3 Building a Binary Search Tree 414

9.3.1 Getting Started 415

9.3.2 Declarations and the Main Function 416

9.3.3 Inserting a Node 417

9.3.4 Finishing the Task 418

9.3.5 Evaluation 419

9.3.6 Random Search Trees and 419

Optimality 419

9.4 Height Balance:AVL Trees 422

9.4.1 Definition 423

9.4.2 Insertion of a Node 424

9.4.3 Deletion of a Node 431

9.4.4 The Height of an AVL Tree 433

9.5.1 Introduction 438

9.5 Splay Trees: 438

A Self-Adjusting Data Structure 438

9.5.2 Splaying Steps 439

9.5.3 Splaying Algorithm 442

9.5.4 Amortized Algorithm Analysis: 446

Introduction 446

9.5.5 Amortized Analysis of Splaying 449

Pointers and Pitfalls 455

Review Questions 456

References for Further Study 458

Multiway Trees 459

10.1 Orchards,Trees,and Binary Trees 460

10.1.1 On the Classification of Species 460

10.1.2 Ordered Trees 461

10.1.3 Forests and Orchards 463

10.1.4 The Formal Correspondence 464

10.1.5 Rotations 465

10.1.6 Summary 466

10.2 Lexicographic Search Trees:Tries 468

10.2.2 Searching for a Key 468

10.2.1 Tries 468

10.2.4 Insertion into a Trie 470

10.2.3 CAlgorithm 470

10.2.5 Deletion from a Trie 472

10.2.6 Assessment of Tries 472

10.3 Extemal Searching:B-Trees 473

10.3.1 Access Time 473

10.3.2 Multiway Search Trees 474

10.3.3 Balanced Mutiway Trees 474

10.3.4 Insertion into a B-tree 475

10.3.5 CAlgorithms: 477

Searching and Insertion 477

10.3.6 Deletionfrom a B-tree 483

10.4 Red-Black Trees 492

10 4.1 Introcuction 492

10.4.2 Definition and Analysis 493

10.4.3 Insertion 495

10.4.4 C Insertion 496

10.5 Tree-Structured Programs: 501

Look-Ahead in Games 501

10.5.1 Game Trees 501

10.5.2 The Minimax Method 502

10.5.3 Algorithm Development 503

10.5.4 Refinement 504

Pointers and Pitfalls 507

Review Questions 507

References for Further Study 508

Graphs 510

11.1.1 Definitions and Examples 511

11.1 Mathematical Background 511

11.1.2 Undirected Graphs 512

11.1.3 Directed Graphs 512

11.2 Computer Representation 513

11.3 Graph Traversal 517

11.3.1 Methods 517

11.3.2 Depth-First Algorithm 518

11.3.3 Breadth-First Algorithm 519

11.4 Topological Sorting 520

11.4.1 The Problem 520

11.4.2 Depth-First Algorithm 522

11.4.3 Breadth-First Algorithm 523

11.5 A Greedy Algorithm: 525

Shortest Paths 525

11.6 Graphs as Data Structures 529

Pointers and Pitfalls 531

Review Questions 532

References for Further Study 532

Case Study:The Polish Notation 533

12.1 The Problem 534

12.1.1 The Quadratic Formula 534

12.2.1 Expression Trees 536

12.2 The Idea 536

12.2.2 Polish Notation 538

12.2.3 C Method 539

12.3 Evaluation of Polish Expressions 540

12.3.1 Evaluation of an Expression inPrefix Form 540

12.3.2 C Conventions 541

12.3.3 C Function for Prefix Evaluation 542

12.3.4 Evaluation of Postfix Expressions 542

12.3.5 Proof of the Program: 544

Counting Stack Entries 544

12.3.6 Recursive Evaluafion of 547

Postfix Expressions 547

12.4 Translation from Infix Form to PolishForm 551

12.5.1 Overall Structure 558

12.5 An Interactive Expression 558

Evaluator 558

12 5.2 Representation of the Data 560

12.5.3 Initialization and Auxiliary Tasks 562

12.5.4 Translation of the Expression 566

12.5.5 Evaluating the Expression 574

12.5.6 Graphing the Expression 576

References for Further Study 578

APPENDIX A 579

Mathematical Methods 579

A.1 Sums of Powers of Integers 580

A.2 Logarithms 582

A.2.2 Simple Properties 583

A.2.1 Definition of Logarithms 583

A.2.3 Choice of Base 584

A.2.4 Natural Logarithms 584

A.2.5 Notation 585

A.2.6 Change of Base 586

A.2.7 Logarithmic Graphs 586

A.2.8 Harmonic Numbers 588

A.3 Permutations,Combinations, 589

Factorials 589

A.3.1 Permutatiors 589

A.3.2 Combinations 589

A.3.3 Factorials 590

A.4 Fibonacci Numbers 592

A.5.2 The Proof by One-to-One 594

Correspondences 594

A.5 Catalan Numbers 594

A.5.1 The Main Result 594

A.5.3 History 596

A.5.4 Numerical Results 597

References for Further Study 598

APPiENDIX B 600

Removal of Recursion 600

B.1 General Methods for Removing 601

Recursion 601

B.1.1 Preliminary Assumptions 601

B.1.2 General Rules 602

B.1.3 Indirect Recursion 603

B.1.4 Towers of Hanoi 603

B.1.5 Further Simplifications 605

B.2 Recursion Removal by Folding 606

B.2.1 Program Schemata 606

B.2.2 Proof of the Transformation 607

B.2.3 Towers of Hanoi: 609

The Final Version 609

B.3 Nonrecursive Quicksort 611

B.4 Stackless Recursion Removal: 613

Mergesort 613

B.5 Threaded Binary Trees 617

B.5.1 Introduction 617

B.5.2 Threads 619

B.5.3 Inorder and Preorder Traversal 620

B.5 4 Insertion in a Threaded Tree 621

B.5.5 Postorder Traversal 623

References for Further Study 627

APPENDIX C 628

An Introduction to C 628

C.1 Introduction 629

C.1.1 Overview of a C Program 629

C.2 C Elements 629

C.2.1 Reserved Words 629

C.2.2 Constants 629

C.3 Types and Declarations 631

C.3.1 Basic Types 631

C.3.2 Arrays 631

C.3.3 Enumerations 631

C.3.5 Unions 632

C.3.4 Structures 632

C.3.6 Type Definitions with typedef 634

C.4 Operators 635

C.5 Control Flow Statements 636

C.5.1 If-Else 636

C.5.2 Switch 636

C.5 3 Loops 637

C.5.4 Break and Continue 637

C.5.5 Goto 637

C.6 Pointers 638

C.6.1 Pointer to a Simple Variable 638

C.6.2 Pointer to an Array 639

C.6 3 Array of Pointers 640

C.6.4 Pointer to Structures 641

C.7 Functions 642

C.7.1 Arguments to Functions: 642

Call by Value 642

C.7.2 Arguments to Functions: 643

Call by Reference 643

C.7.3 Function Prototypes and IncludeFiles 644

C.8 Pointers and Functions 644

C.8.1 Pointer to a Function 644

C.8.2 Functions that Return a Pointer 645

C.8.3 Pointer to a Pointer as an 646

Argument 646

References for Further Study 647

INDEX 649