1 / 10

Stacks

Stacks. Standard operations: IsEmpty … return true iff stack is empty Top … return top element of stack Push … add an element to the top of the stack Pop … delete the top element of the stack. Stacks. Use a 1D array to represent a stack.

leveille
Download Presentation

Stacks

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Stacks • Standard operations: • IsEmpty … return true iff stack is empty • Top … return top element of stack • Push … add an element to the top of the stack • Pop … delete the top element of the stack

  2. Stacks • Use a 1D array to represent a stack. • Stack elements are stored in stack[0] through stack[top].

  3. a b c d e 0 1 2 3 4 5 6 Stacks • stack top is at element e • IsEmpty() => check whether top >= 0 • O(1) time • Top() => If not empty return stack[top] • O(1) time

  4. a b c d e 0 1 2 3 4 5 6 Derive From arrayList • Push(theElement) => if array full (top == capacity – 1) increase capacity and then add at stack[top+1] • O(capacity) time when full; otherwise O(1) • pop() => if not empty, delete from stack[top] • O(1) time

  5. The Class Stack template<class T> class Stack { public: Stack(int stackCapacity = 10); ~Stack() {delete [] stack;} bool IsEmpty() const; T& Top() const; void Push(const T& item); void Pop(); private: T *stack; // array for stack elements int top; // position of top element int capacity; // capacity of stack array };

  6. Constructor template<class T> Stack<T>::Stack(int stackCapacity) :capacity(stackCapacity) { if (capacity < 1) throw “Stack capacity must be > 0”; stack = new T[capacity]; top = -1; }

  7. IsEmpty template<class T> inline bool Stack<T>::IsEmpty() const {return top == -1}

  8. Top template<class T> inline T& Stack<T>::Top() const { if (IsEmpty()) throw “Stack is empty”; return stack[top]; }

  9. top a b c d e 0 1 2 3 4 Push template<class T> void Stack<T>::Push(const T& x) {// Add x to the stack. if (top == capacity - 1) {ChangeSize1D(stack, capacity, 2*capacity); capacity *= 2; } // add at stack top stack[++top] = x; }

  10. top a b c d e 0 1 2 3 4 Pop void Stack<T>::Pop() { if (IsEmpty()) throw “Stack is empty. Cannot delete.”; stack[top--].~T(); // destructor for T }

More Related