ebook img

Data Structures and Algorithms Using C PDF

366 Pages·2007·5.17 MB·English
by  
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview Data Structures and Algorithms Using C

P1:FCW 0521670152pre CUNY656/McMillan Printer:cupusbw 0521670152 February17,2007 20:59 D S ATA TRUCTURES AND A U C# LGORITHMS SING C# programmers: no more translating data structures from C++ or Java to useinyourprograms!MikeMcMillanprovidesatutorialonhowtousedata structuresandalgorithmsplusthefirstcomprehensivereferenceforC#imple- mentation of data structures and algorithms found in the .NET Framework library,aswellasthosedevelopedbytheprogrammer. The approach is very practical, using timing tests rather than Big O nota- tion to analyze the efficiency of an approach. Coverage includes array and ArrayLists, linked lists, hash tables, dictionaries, trees, graphs, and sorting andsearchingalgorithms,aswellasmoreadvancedalgorithmssuchasprob- abilistic algorithms and dynamic programming. This is the perfect resource forC#professionalsandstudentsalike. MichaelMcMillanisInstructorofComputerInformationSystemsatPulaski Technical College, as well as an adjunct instructor at the University of ArkansasatLittleRockandtheUniversityofCentralArkansas.Mike’sprevi- ous books include Object-Oriented Programming with Visual Basic.NET, Data StructuresandAlgorithmsUsingVisualBasic.NET,andPerlfromtheGroundUp. Heisaco-authorofProgrammingandProblem-SolvingwithVisualBasic.NET. Mikehaswrittenmorethantwenty-fivetradejournalarticlesonprogramming andhasmorethantwentyyearsofexperienceprogrammingforindustryand education. P1:FCW 0521670152pre CUNY656/McMillan Printer:cupusbw 0521670152 February17,2007 20:59 P1:FCW 0521670152pre CUNY656/McMillan Printer:cupusbw 0521670152 February17,2007 20:59 D S ATA TRUCTURES AND A U C# LGORITHMS SING M M M ICHAEL C ILLAN PulaskiTechnicalCollege CAMBRIDGEUNIVERSITYPRESS Cambridge, New York, Melbourne, Madrid, Cape Town, Singapore, São Paulo Cambridge University Press The Edinburgh Building, Cambridge CB28RU, UK Published in the United States of America by Cambridge University Press, New York www.cambridge.org Information on this title: www.cambridge.org/9780521876919 © Michael McMillan 2007 This publication is in copyright. Subject to statutory exception and to the provision of relevant collective licensing agreements, no reproduction of any part may take place without the llausv permission of Cambridge University Press. First published in print format 2007 ISBN-13 978-0-521-87691-9 hardback ISBN-10 0-521-87691-5 hardback ISBN-13 978-0-521-67015-9 paperback ISBN-10 0-521-67015-2 paperback Cambridge University Press has no responsibility for the persistence or accuracy of urls for external or third-party internet websites referred to in this publication, and does not guarantee that any content on such websites is, or will remain, accurate or appropriate. P1:FCW 0521670152pre CUNY656/McMillan Printer:cupusbw 0521670152 February17,2007 20:59 Contents Preface page vii Chapter 1 An Introduction to Collections, Generics, and the Timing Class 1 Chapter 2 Arrays and ArrayLists 26 Chapter 3 Basic Sorting Algorithms 42 Chapter 4 Basic Searching Algorithms 55 Chapter 5 Stacks and Queues 68 Chapter 6 The BitArray Class 94 Chapter 7 Strings, the String Class, and the StringBuilder Class 119 Chapter 8 Pattern Matching and Text Processing 147 v P1:FCW 0521670152pre CUNY656/McMillan Printer:cupusbw 0521670152 February17,2007 20:59 vi CONTENTS Chapter 9 Building Dictionaries: The DictionaryBase Class and the SortedList Class 165 Chapter 10 Hashing and the Hashtable Class 176 Chapter 11 Linked Lists 194 Chapter 12 Binary Trees and Binary Search Trees 218 Chapter 13 Sets 237 Chapter 14 Advanced Sorting Algorithms 249 Chapter 15 Advanced Data Structures and Algorithms for Searching 263 Chapter 16 Graphs and Graph Algorithms 283 Chapter 17 Advanced Algorithms 314 References 339 Index 341 P1:FCW 0521670152pre CUNY656/McMillan Printer:cupusbw 0521670152 February17,2007 20:59 Preface The study of data structures and algorithms is critical to the development of the professional programmer. There are many, many books written on datastructuresandalgorithms,butthesebooksareusuallywrittenascollege textbooksandarewrittenusingtheprogramminglanguagestypicallytaught in college—Java or C++. C# is becoming a very popular language and this bookprovidestheC#programmerwiththeopportunitytostudyfundamental datastructuresandalgorithms. C#existsinaveryrichdevelopmentenvironmentcalledthe.NETFrame- work.Includedinthe.NETFrameworklibraryisasetofdatastructureclasses (also called collection classes), which range from the Array, ArrayList, and Collection classes to the Stack and Queue classes and to the HashTable and theSortedListclasses.Thedatastructuresandalgorithmsstudentcannowsee how to use a data structure before learning how to implement it. Previously, an instructor had to discuss the concept of, say, a stack, abstractly until the completedatastructurewasconstructed.Instructorscannowshowstudents howtouseastacktoperformsomecomputation,suchasnumberbasecon- versions, demonstrating the utility of the data structure immediately. With thisbackground,thestudentcanthengobackandlearnthefundamentalsof thedatastructure(oralgorithm)andevenbuildtheirownimplementation. This book is written primarily as a practical overview of the data struc- tures and algorithms all serious computer programmers need to know and understand.Giventhis,thereisnoformalanalysisofthedatastructuresand algorithms covered in the book. Hence, there is not a single mathematical formulaandnotonementionofBigOhanalysis(ifyoudon’tknowwhatthis means,lookatanyofthebooksmentionedinthebibliography).Instead,the variousdatastructuresandalgorithmsarepresentedasproblem-solvingtools. vii P1:FCW 0521670152pre CUNY656/McMillan Printer:cupusbw 0521670152 February17,2007 20:59 viii PREFACE Simpletimingtestsareusedtocomparetheperformanceofthedatastructures andalgorithmsdiscussedinthebook. PREREQUISITES The only prerequisite for this book is that the reader have some familiarity with the C# language in general, and object-oriented programming in C# in particular. CHAPTER-BY-CHAPTER ORGANIZATION Chapter 1 introduces the reader to the concept of the data structure as a collectionofdata.Theconceptsoflinearandnonlinearcollectionsareintro- duced.TheCollectionclassisdemonstrated.Thischapteralsointroducesthe conceptofgenericprogramming,whichallowstheprogrammertowriteone class,oronemethod,andhaveitworkforamultitudeofdatatypes.Generic programming is an important new addition to C# (available in C# 2.0 and beyond), so much so that there is a special library of generic data structures found in the System.Collections.Generic namespace. When a data structure has a generic implementation found in this library, its use is discussed. The chapterendswithanintroductiontomethodsofmeasuringtheperformance ofthedatastructuresandalgorithmsdiscussedinthebook. Chapter 2 provides a review of how arrays are constructed, along with demonstrating the features of the Array class. The Array class encapsulates many of the functions associated with arrays (UBound, LBound, and so on) into a single package. ArrayLists are special types of arrays that provide dynamicresizingcapabilities. Chapter 3 is an introduction to the basic sorting algorithms, such as the bubble sort and the insertion sort, and Chapter 4 examines the most funda- mentalalgorithmsforsearchingmemory,thesequentialandbinarysearches. Two classic data structures are examined in Chapter 5: the stack and the queue. The emphasis in this chapter is on the practical use of these data structuresinsolvingeverydayproblemsindataprocessing.Chapter6covers the BitArray class, which can be used to efficiently represent a large number ofintegervalues,suchastestscores. Strings are not usually covered in a data structures book, but Chapter 7 coversstrings,theStringclass,andtheStringBuilderclass.Becausesomuch P1:FCW 0521670152pre CUNY656/McMillan Printer:cupusbw 0521670152 February17,2007 20:59 PREFACE ix dataprocessinginC#isperformedonstrings,thereadershouldbeexposed to the special techniques found in the two classes. Chapter 8 examines the useofregularexpressionsfortextprocessingandpatternmatching.Regular expressions often provide more power and efficiency than can be had with moretraditionalstringfunctionsandmethods. Chapter9introducesthereadertotheuseofdictionariesasdatastructures. Dictionaries, and the different data structures based on them, store data as key/value pairs. This chapter shows the reader how to create his or her own classes based on the DictionaryBase class, which is an abstract class. Chap- ter 10 covers hash tables and the HashTable class, which is a special type of dictionarythatusesahashingalgorithmforstoringdatainternally. Another classic data structure, the linked list, is covered in Chapter 11. Linked lists are not as important a data structure in C# as they are in a pointer-basedlanguagesuchasC++,buttheystillhavearoleinC#program- ming.Chapter12introducesthereadertoyetanotherclassicdatastructure— the binary tree. A specialized type of binary tree, the binary search tree, is the primary topic of the chapter. Other types of binary trees are covered in Chapter15. Chapter13showsthereaderhowtostoredatainsets,whichcanbeusefulin situationsinwhichonlyuniquedatavaluescanbestoredinthedatastructure. Chapter14covers more advanced sorting algorithms, including the popular andefficientQuickSort,whichisthebasisformostofthesortingprocedures implementedinthe.NETFrameworklibrary.Chapter15looksatthreedata structures that prove useful for searching when a binary search tree is not calledfor:theAVLtree,thered-blacktree,andtheskiplist. Chapter 16 discusses graphs and graph algorithms. Graphs are useful for representingmanydifferenttypesofdata,especiallynetworks.Finally,Chap- ter 17 introduces the reader to what algorithm design techniques really are: dynamicalgorithmsandgreedyalgorithms. ACKNOWLEDGEMENTS Thereareseveraldifferentgroupsofpeoplewhomustbethankedforhelping me finish this book. First, thanks to a certain group of students who first satthroughmylecturesondevelopingdatastructuresandalgorithms.These studentsinclude(notinanyparticularorder):MattHoffman,KenChen,Ken Cates,JeffRichmond,andGordonCaffey.Also,oneofmyfellowinstructors at Pulaski Technical College, Clayton Ruff, sat through many of the lectures

Description:
C# programmers: no more translating data structures from C++ or Java to structures and algorithms plus the first comprehensive reference for C#
See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.