Stack Implementation In C++ (original) (raw)
It is a user define memory buffer to store return addresses and temporary variables.
Data structures and program design in C
2007
Preface functions and complete programs of substantial length. The exercises and programming projects, moreover, constitute an indispensable part of the book. Many of these are immediate applications of the topic under study, often requesting that programs be written and run, so that algorithms may be tested and compared. Some are larger projects, and a few are suitable for use by a small group of students working together. Our programs are written in the popular object-oriented language C++. We take the view that many object-oriented techniques provide natural implementations for basic principles of data-structure design. In this way, C++ allows us to construct safe, efficient, and simple implementations of data-structures. We recognize that C++ is sufficiently complex that students will need to use the experience of a data structures courses to develop and refine their understanding of the language. We strive to support this development by carefully introducing and explaining various object-oriented features of C++ as we progress through the book. Thus, we begin Chapter 1 assuming that the reader is comfortable with the elementary parts of C++ (essentially, with the C subset), and gradually we add in such object-oriented elements of C++ as classes, methods, constructors, inheritance, dynamic memory management, destructors, copy constructors, overloaded functions and operations, templates, virtual functions, and the STL. Of course, our primary focus is on the data structures themselves, and therefore students with relatively little familiarity with C++ will need to supplement this text with a C++ programming text. SYNOPSIS By working through the first large project (CONWAY's game of Life), Chapter 1 Programming Principles expounds principles of object-oriented program design, top-down refinement, review, and testing, principles that the student will see demonstrated and is expected to follow throughout the sequel. At the same time, this project provides an opportunity for the student to review the syntax of elementary features of C++, the programming language used throughout the book. Chapter 2 introduces the first data structure we study, the stack. The chapter Preface • Synopsis xiii destructors, copy constructors, and overloaded assignment operators, all of which are needed in the safe C++ implementation of linked structures. Chapter 5 continues to elucidate stacks by studying their relationship to prob-Recursion lem solving and programming with recursion. These ideas are reinforced by exploring several substantial applications of recursion, including backtracking and tree-structured programs. This chapter can, if desired, be studied earlier in a course than its placement in the book, at any time after the completion of Chapter 2. More general lists with their linked and contiguous implementations provide Lists and Strings the theme for Chapter 6. The chapter also includes an encapsulated string implementation, an introduction to C++ templates, and an introduction to algorithm analysis in a very informal way. Chapter 7, Chapter 8, and Chapter 9 present algorithms for searching, sorting, Searching and table access (including hashing), respectively. These chapters illustrate the interplay between algorithms and the associated abstract data types, data struc-Sorting tures, and implementations. The text introduces the "big-O " and related notations for elementary algorithm analysis and highlights the crucial choices to be made regarding best use of space, time, and programming effort. These choices require Tables and Information Retrieval that we find analytical methods to assess algorithms, and producing such analyses is a battle for which combinatorial mathematics must provide the arsenal. At an elementary level we can expect students neither to be well armed nor to possess the mathematical maturity needed to hone their skills to perfection. Our goal, therefore, is to help students recognize the importance of such skills in anticipation of later chances to study mathematics. Binary trees are surely among the most elegant and useful of data structures. Their study, which occupies Chapter 10, ties together concepts from lists, searching, Binary Trees and sorting. As recursively defined data structures, binary trees afford an excellent opportunity for the student to become comfortable with recursion applied both to data structures and algorithms. The chapter begins with elementary topics and progresses as far as such advanced topics as splay trees and amortized algorithm analysis. Chapter 11 continues the study of more sophisticated data structures, including Multiway Trees tries, B-trees, and red-black trees. Chapter 12 introduces graphs as more general structures useful for problem Graphs solving, and introduces some of the classical algorithms for shortest paths and minimal spanning trees in graphs. The case study in Chapter 13 examines the Polish notation in considerable detail, exploring the interplay of recursion, trees, and stacks as vehicles for problem Case Study: The Polish Notation solving and algorithm development. Some of the questions addressed can serve as an informal introduction to compiler design. As usual, the algorithms are fully developed within a functioning C++ program. This program accepts as input an expression in ordinary (infix) form, translates the expression into postfix form, and evaluates the expression for specified values of the variable(s). Chapter 13 may be studied anytime after the completion of Section 10.1. The appendices discuss several topics that are not properly part of the book's subject but that are often missing from the student's preparation. Appendix A presents several topics from discrete mathematics. Its final two Mathematical Methods sections, Fibonacci numbers amd Catalan numbers, are more advanced and not xiv Preface needed for any vital purpose in the text, but are included to encourage combinatorial interest in the more mathematically inclined. Appendix B discusses pseudorandom numbers, generators, and applications, Random Numbers a topic that many students find interesting, but which often does not fit anywhere in the curriculum. Appendix C catalogues the various utility and data-structure packages that are Packages and Utility Functions developed and used many times throughout this book. Appendix C discusses declaration and definition files, translation units, the utility package used throughout the book, and a package for calculating CPU times. Appendix D, finally, collects all the Programming Precepts and all the Pointers Programming Precepts, Pointers, and Pitfalls and Pitfalls scattered through the book and organizes them by subject for convenience of reference. COURSE STRUCTURE The prerequisite for this book is a first course in programming, with experience prerequisite using the elementary features of C++. However, since we are careful to introduce sophisticated C++ techniques only gradually, we believe that, used in conjunction with a supplementary C++ textbook and extra instruction and emphasis on C++ language issues, this text provides a data structures course in C++ that remains suitable even for students whose programming background is in another language such as C, Pascal, or Java. A good knowledge of high school mathematics will suffice for almost all the algorithm analyses, but further (perhaps concurrent) preparation in discrete mathematics will prove valuable. Appendix A reviews all required mathematics. This book is intended for courses such as the ACM Course CS2 (Program Design content and Implementation), ACM Course CS7 (Data Structures and Algorithm Analysis), or a course combining these. Thorough coverage is given to most of the ACM/IEEE knowledge units 1 on data structures and algorithms. These include: AL1 Basic data structures, such as arrays, tables, stacks, queues, trees, and graphs; AL2 Abstract data types; AL3 Recursion and recursive algorithms; AL4 Complexity analysis using the big Oh notation; AL6 Sorting and searching; and AL8 Practical problem-solving strategies, with large case studies. The three most advanced knowledge units, AL5 (complexity classes, NP-complete problems), AL7 (computability and undecidability), and AL9 (parallel and distributed algorithms) are not treated in this book.
THE REVIEW ON IMPLEMENTATION OF CIRCULAR STACK DATA STRUCTURE
This paper presents concepts of data structures and its use. As new trend in computers have made it possible to handle complex problems. Requirements of users are also becoming large and complex and to solve these problems basic data types are not sufficient. Thus there is a need for “Data structure”, which gives more “structure” to data. These data structures may be a combination or collection of basic data types, with specific properties and operations. This paper also describes one of data structure that is stack which provides push and pop operations with the usual semantics also the working of the single stack and multiple stack and its applications. It mainly focuses on a new implementation technique on data structure called Circular stack. This is an amazing concept where the single stack works as multiple stacks in circular form.
The computing world has undergone a revolution since the publication of The C Programming Language in 1978. Big computers are much bigger, and personal computers have capabilities that rival mainframes of a decade ago. During this time, C has changed too, although only modestly, and it has spread far beyond its origins as the language of the UNIX operating system.