55
DataStruct 5. Stacks, Queues, and Deques 2013-2 O-O Programming & Data Structure October 30, 2013 Prof. Young-Tak Kim Advanced Networking Technology Lab. (YU-ANTL) Dept. of Information & Comm. Eng, College of Engineering, Yeungnam University, KOREA (Tel : +82-53-810-2497; Fax : +82-53-810-4742 http://antl.yu.ac.kr/; E-mail : [email protected]) Michael T. Goodrich, et. al, Data Structures and Algorithms in C++, 2 nd Ed., John Wiley & Sons, Inc., 2011.

DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

  • Upload
    others

  • View
    5

  • Download
    0

Embed Size (px)

Citation preview

Page 1: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

DataStruct 5. Stacks, Queues, and Deques

2013-2 O-O Programming & Data Structure

October 30, 2013

Prof. Young-Tak Kim Advanced Networking Technology Lab. (YU-ANTL)

Dept. of Information & Comm. Eng, College of Engineering, Yeungnam University, KOREA

(Tel : +82-53-810-2497; Fax : +82-53-810-4742 http://antl.yu.ac.kr/; E-mail : [email protected])

Michael T. Goodrich, et. al, Data Structures and Algorithms in C++, 2nd Ed., John Wiley & Sons, Inc., 2011.

Page 2: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 2

Outline

Stacks Last In First Out (LIFO)

Queues First In First Out (FIFO)

Double-Ended Queues (deque)

Page 3: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 3

Abstract Data Types (ADTs)

An abstract data type (ADT) is an abstraction of a data structure

An ADT specifies: Data stored Operations on the data Error conditions associated with operations

Example: ADT modeling a simple stock trading

system The data stored are buy/sell orders The operations supported are order buy(stock, shares, price) order sell(stock, shares, price) void cancel(order)

Error conditions: Buy/sell a nonexistent stock Cancel a nonexistent order

Page 4: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 4

5.1 Stack

The Stack ADT stores arbitrary objects Insertions and deletions follow the last-in first-

out scheme Think of a spring-loaded plate dispenser Main stack operations: push(object): inserts an element object pop(): removes the last inserted element

Auxiliary stack operations: object top(): returns the last inserted element without removing

it integer size(): returns the number of elements stored boolean empty(): indicates whether no elements are stored

Page 5: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 5

Stack Interface in C++

C++ interface corresponding to our Stack ADT Uses an exception class StackEmpty Different from the built-in C++ STL class stack

template <typename E> class Stack { // an interface for a stack public:

int size() const; // number of items in stack bool empty() const; // is the stack empty? const E& top() const throw(StackEmpty); // the top element void push(const E& e); // push x onto the stack void pop() throw(StackEmpty); // remove the top element

};

Page 6: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 6

Exceptions

Attempting the execution of an operation of ADT may sometimes cause an error condition, called an exception

Exceptions are said to be “thrown” by an operation that cannot be executed

In the Stack ADT, operations pop() and top() cannot be performed if the stack is empty

Attempting pop() or top() on an empty stack throws a StackEmpty exception class StackEmpty : public RuntimeException { public:

StackEmpty(const string& err) : RuntimeException(err){} };

Page 7: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 7

Applications of Stacks

Direct applications Page-visited history in a Web browser (e.g., keeping recently

visited web site URLs) Undo sequence in a text editor Chain of method calls in the C++ run-time system

Indirect applications Auxiliary data structure for algorithms Stack is used as a component of other data structures

Page 8: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 8

C++ Run-Time Stack

The C++ run-time system keeps track of the chain of active functions with a stack

When a function is called, the system pushes on the stack a frame containing Local variables and return value Program counter, keeping track of

the statement being executed When the function ends, its

frame is popped from the stack and control is passed to the function on top of the stack

Allows for recursion

main() { int i = 5; foo(i); }

foo(int j) { int k; k = j+1; bar(k); }

bar(int m) { … }

bar PC = 1 m = 6

foo PC = 3 j = 5 k = 6

main PC = 2 i = 5

Page 9: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 9

Array-based Stack

A simple way of implementing the Stack ADT uses an array

We add elements from left to right

A variable keeps track of the index of the top element

S 0 1 2 t

Algorithm size() return t + 1 Algorithm pop() if empty() then throw StackEmpty else t ← t − 1 return S[t + 1]

Page 10: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 10

Array-based Stack (cont.)

The array storing the stack elements may become full

A push operation will then throw a StackFull exception Limitation of the array-

based implementation Not intrinsic to the Stack

ADT

S 0 1 2 t

Algorithm push(o) if t = S.size() − 1 then throw StackFull else t ← t + 1 S[t] ← o

Page 11: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 11

Performance and Limitations

Performance Let n be the number of elements in the stack The space used is O(n) Each operation (push(), pop()) runs in time O(1)

Limitations The maximum size of the stack must be defined a

priori and cannot be changed Trying to push a new element into a full stack causes

an implementation-specific exception

Page 12: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 12

Array-based Stack in C++

template <typename E> class ArrayStack {

enum { DEF_CAPACITY = 100 }; // default stack capacity public:

ArrayStack(int cap = DEF_CAPACITY); // constructor from capacity int size() const; // number of items in the stack bool empty() const; // is the stack empty? const E& top() const throw(StackEmpty); // get the top element void push(const E& e) throw(StackFull); // push element onto stack void pop() throw(StackEmpty); // pop the stack // ...housekeeping functions omitted

private: // member data E* S; // array of stack elements int capacity; // stack capacity int t; // index of the top of the stack

};

Page 13: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 13

Member functions of Stack (1) template <typename E> ArrayStack<E>::ArrayStack(int cap) // constructor with given capacity : S (new E[cap]), capacity(cap), t(-1) { } template <typename E> int ArrayStack<E>::size() const {

return (t + 1); } // number of items in the stack template <typename E> int ArrayStack<E>::empty() const {

return (t < 0); } // is stack empty ?

Page 14: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 14

Member functions of Stack (2)

template <typename E> ArrayStack<E>::top() const throw(StackEmpty) {

if (empty()) throw StackEmpty(“Top of empty stack”); return S[t];

} template <typename E> // push element onto the stack void ArrayStack<E>::push(const E& e) throw(StackFull) {

if (size() == capacity) throw StackFull("Push to full stack"); S[++t] = e;

} template <typename E> // pop the stack void ArrayStack<E>::pop() throw(StackEmpty) {

if (empty()) throw StackEmpty("Pop from empty stack"); --t;

}

Page 15: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 15

Example use in C++

ArrayStack<int> A; // A = [ ], size = 0 A.push(7); // A = [7*], size = 1 A.push(13); // A = [7, 13*], size = 2 cout << A.top() << endl; A.pop(); // A = [7*], outputs: 13 A.push(9); // A = [7, 9*], size = 2 cout << A.top() << endl; // A = [7, 9*], outputs: 9 cout << A.top() << endl; A.pop(); // A = [7*], outputs: 9 ArrayStack<string> B(10); // B = [ ], size = 0 B.push("Bob"); // B = [Bob*], size = 1 B.push("Alice"); // B = [Bob, Alice*], size = 2 cout << B.top() << endl; B.pop(); // B = [Bob*], outputs: Alice B.push("Eve"); // B = [Bob, Eve*], size = 2

* indicates top

Page 16: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 16

Implementing a Stack with a Generic Linked List

SLinkedList (Code Fragment 3.18, 3.19)

template <typename E> class SLinkedList { // a singly linked list public:

SLinkedList(); // empty list constructor ~SLinkedList(); // destructor bool empty() const; // is list empty? const E& front() const; // return front element void addFront(const E& e); // add to front of list void removeFront(); // remove front item list

private: SNode<E>* head; // head of the list

};

template <typename E> class SNode { // a singly linked list node

friend class SLinkedList<E>; private:

E elem; // linked list element value SNode<E>* next; // next item in the list

};

Page 17: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 17

LinkedStack (Code Fragment 5.7) typedef string Elem; // stack element type class LinkedStack { // stack as a linked list public:

LinkedStack(); // constructor int size() const; // number of items in the stack bool empty() const; // is the stack empty? const Elem& top() const throw(StackEmpty); // the top element void push(const Elem& e); // push element onto stack void pop() throw(StackEmpty); // pop the stack

private: // member data SLinkedList<Elem> S; // linked list of elements int n; // number of elements

};

Page 18: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 18

Member functions of LinkedStack (1) LinkedStack::LinkedStack() // constructor

: S(), n(0) { } // constructor int LinkedStack::size() const {

return n; } // number of items in the stack bool LinkedStack::empty() const {

return n == 0; } // is the stack empty?

Page 19: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 19

Member functions of LinkedStack (2)

const Elem& LinkedStack::top() const throw(StackEmpty) {

if (empty()) throw StackEmpty("Top of empty stack"); return S.front();

} void LinkedStack::push(const Elem& e) { // push element onto stack

++n; S.addFront(e);

} // pop the stack void LinkedStack::pop() throw(StackEmpty) {

if (empty()) throw StackEmpty("Pop from empty stack"); --n; S.removeFront();

}

Page 20: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 20

Parentheses Matching

Each “(”, “{”, or “[” must be paired with a matching “)”, “}”, or “[” correct: ( )(( )){([( )])} correct: ((( )(( )){([( )])} incorrect: )(( )){([( )])} incorrect: ({[ ])} incorrect: (

Page 21: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 21

Parentheses Matching Algorithm

Algorithm ParenMatch(X,n): Input: An array X of n tokens, each of which is either a grouping symbol, a

variable, an arithmetic operator, or a number Output: true if and only if all the grouping symbols in X match Let S be an empty stack for i=0 to n-1 do if X[i] is an opening grouping symbol then S.push(X[i]) else if X[i] is a closing grouping symbol then if S.empty() then return false {nothing to match with} if S.pop() does not match the type of X[i] then return false {wrong type} if S.empty() then return true {every symbol matched} else return false {some symbols were never matched}

Page 22: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 22

Evaluating Arithmetic Expressions

14 – 3 * 2 + 7 = (14 – (3 * 2) ) + 7 Operator precedence * has precedence over +/– Associativity operators of the same precedence group evaluated from left to right Example: (x – y) + z rather than x – (y + z)

Idea: push each operator on the stack, but first pop and perform higher and equal precedence operations.

Page 23: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 23

Algorithm for Evaluating Expressions

// Using two stacks: // opStk holds operators // valStk holds values // Use $ as special “end of input” // token with lowest precedence

Algorithm doOp()

x ← valStk.pop(); y ← valStk.pop(); op ← opStk.pop(); valStk.push( y op x );

Algorithm repeatOps( refOp ) while ( (valStk.size() > 1) ∧ (prec(refOp) ≤ prec(opStk.top())) doOp()

Algorithm EvalExp() Input: a stream of tokens

representing an arithmetic expression (with numbers)

Output: the value of the expression

while there’s another token z if isNumber(z) then valStk.push(z) else // operator repeatOps(z); opStk.push(z) repeatOps($); return valStk.top()

Page 24: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 24

Algorithm on an Example Expression

14 ≤ 4 – 3 * 2 + 7 Operator ≤ has lower precedence than +/–

– ≤ 14

4

* 3 – ≤ 14

4

2 * 3 – ≤ 14

4

+

2 * 3 – ≤ 14

4

+

6 – ≤ 14

4 + ≤ 14

-2

$

7 + ≤ 14

-2

$

F $

≤ 14 5

Page 25: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 25

5.2 Queues

The Queue ADT stores arbitrary objects Insertions and deletions follow the first-in first-out scheme Insertions are at the rear of the queue and removals are at

the front of the queue Main queue operations: enqueue(object): inserts an element at the end of the queue dequeue(): removes the element at the front of the queue

Auxiliary queue operations: object front(): returns the element at the front without removing

it integer size(): returns the number of elements stored boolean empty(): indicates whether no elements are stored

Exceptions Attempting the execution of dequeue or front on an empty queue

throws an QueueEmpty

Page 26: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 26

Informal Queue Interface (not a complete C++ class)

template <typename E> class Queue { // an interface for a queue public:

int size() const; // number of items in queue bool empty() const; // is the queue empty? const E& front() const throw(QueueEmpty); // the front element void enqueue (const E& e); // enqueue element at rear void dequeue() throw(QueueEmpty); // dequeue element at front

};

class QueueEmpty : public RuntimeException { public:

QueueEmpty(const string& err) : RuntimeException(err) { } };

Page 27: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 27

Example

Operation Output Q enqueue(5) – (5) enqueue(3) – (5, 3) dequeue() – (3) enqueue(7) – (3, 7) dequeue() – (7) front() 7 (7) dequeue() – () dequeue() “error” () empty() true () enqueue(9) – (9) enqueue(7) – (9, 7) size() 2 (9, 7) enqueue(3) – (9, 7, 3) enqueue(5) – (9, 7, 3, 5) dequeue() – (7, 3, 5)

Page 28: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 28

Applications of Queues

Direct applications Waiting lists, bureaucracy Access to shared resources (e.g., printer) Multiprogramming

Indirect applications Auxiliary data structure for algorithms Component of other data structures

Page 29: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 29

Array-based Queue

Use an array of size N in a circular fashion Three variables keep track of the front and rear

f index of the front element r index immediately past the rear element n number of items in the queue

Q 0 1 2 r f

normal configuration

Q 0 1 2 f r

wrapped-around configuration

Page 30: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 30

Queue Operations

Use n to determine size and emptiness

Algorithm size() return n Algorithm empty() return (n = 0)

Q 0 1 2 r f

Q 0 1 2 f r

Page 31: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 31

Queue Operations (cont.)

Algorithm enqueue(o) if size() = N then throw QueueFull else Q[r] ← o r ← (r + 1) mod N n ← n + 1

Operation enqueue throws an exception if the array is full

This exception is implementation-dependent

Q 0 1 2 r f

Q 0 1 2 f r

Page 32: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 32

Queue Operations (cont.)

Operation dequeue throws an exception if the queue is empty

This exception is specified in the queue ADT

Algorithm dequeue() if empty() then throw QueueEmpty else f ← (f + 1) mod N n ← n − 1

Q 0 1 2 r f

Q 0 1 2 f r

Page 33: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 33

Queue Interface in C++

C++ interface corresponding to our Queue ADT

Requires the def-inition of exception QueueEmpty

No corresponding built-in C++ class

template <typename E> class Queue { public: int size() const; bool empty() const; const E& front() const throw(QueueEmpty); void enqueue (const E& e); void dequeue() throw(QueueEmpty); };

Page 34: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 34

Application: Round Robin Schedulers

We can implement a round robin scheduler using a queue Q by repeatedly performing the following steps:

1. e = Q.front(); Q.dequeue() 2. Service element e 3. Q.enqueue(e)

Shared Service

Queue

Enqueue Dequeue

Page 35: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 35

Implementing a Queue with a Circularly Linked List

Circularly Linked List (Figure 5.5, 5.6)

Page 36: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 36

Circularly Linked List (Code Fragment 3.28, 3.29) typedef string Elem; // element type class CNode { // circularly linked list node

friend class CircleList; // provide CircleList access private:

Elem elem; // linked list element value CNode* next; // next item in the list

};

class CircleList { // a circularly linked list public:

CircleList(); // constructor ~CircleList(); // destructor bool empty() const; // is list empty? const Elem& front() const; // element at cursor const Elem& back() const; // element following cursor void advance(); // advance cursor void add(const Elem& e); // add after cursor void remove(); // remove node after cursor

private: CNode* cursor; // the cursor

};

Page 37: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 37

Circular List (1) CircleList::CircleList() // constructor : cursor(NULL) { } CircleList::~CircleList() // destructor {

while (!empty()) remove(); } bool CircleList::empty() const // is list empty? {

return cursor == NULL; } const Elem& CircleList::back() const // element at cursor {

return cursor->elem; } const Elem& CircleList::front() const // element following cursor {

return cursor->next->elem; } void CircleList::advance() // advance cursor {

cursor = cursor->next; }

Page 38: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 38

Circular List (2) void CircleList::add(const Elem& e) { // add after cursor

CNode* v = new CNode; // create a new node v->elem = e; if (cursor == NULL) { // list is empty?

v->next = v; // v points to itself cursor = v; // cursor points to v

} else { // list is nonempty? v->next = cursor->next; // link in v after cursor cursor->next = v;

} } void CircleList::remove() { // remove node after cursor

CNode* old = cursor->next; // the node being removed if (old == cursor) // removing the only node?

cursor = NULL; // list is now empty else

cursor->next = old->next; // link out the old node delete old; // delete the old node

}

Page 39: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 39

LinkedQueue (1)

typedef string Elem; // queue element type class LinkedQueue { // queue as doubly linked list public:

LinkedQueue(); // constructor int size() const; // number of items in the queue bool empty() const; // is the queue empty? const Elem& front() const throw(QueueEmpty); // the front element void enqueue(const Elem& e); // enqueue element at rear void dequeue() throw(QueueEmpty); // dequeue element at front

private: // member data CircleList C; // circular list of elements int n; // number of elements

};

Page 40: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 40

LinkedQueue (2) LinkedQueue::LinkedQueue() // constructor

: C(), n(0) { } int LinkedQueue::size() const // number of items in the queue { return n; } bool LinkedQueue::empty() const // is the queue empty? { return n == 0; } // get the front element const Elem& LinkedQueue::front() const throw(QueueEmpty) { if (empty())

throw QueueEmpty("front of empty queue"); return C.front(); // list front is queue front }

Page 41: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 41

LinkedQueue (3) // enqueue element at rear

void LinkedQueue::enqueue(const Elem& e) {

C.add(e); // insert after cursor C.advance(); // ...and advance n++;

} // dequeue element at front void LinkedQueue::dequeue() throw(QueueEmpty) {

if (empty()) throw QueueEmpty("dequeue of empty queue"); C.remove(); // remove from list front n--;

}

Page 42: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 42

5.3 Double-Ended Queues (Deque)

Deque Abstract Data Type insertFront(e ) insertBack(e ) eraseFront() eraseBack() front() back() size() empty()

Page 43: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 43

STL Deque

Deque underlying implementation is based on STL vector class

#include <deque> using std::deque; deque<string> myDeque; // list of operations in deque size() empty() push_front(e ) push_back(e ) pop_front() pop_back() front() back()

Page 44: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 44

Implementing a Deque with a Doubly Linked List

class DNode // Code Fragment 3.22 typedef string Elem; // list element type class DNode { // doubly linked list node private: Elem elem; // node element value

DNode* prev; // previous node in list DNode* next; // next node in list friend class DLinkedList; // allow DLinkedList access

};

Page 45: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 45

Handling Doubly Linked List (1) Header and Trailer sentinels (Figure 3.12)

Addition of a node after node (JFK) (Figure 3.13)

Page 46: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 46

Handling Doubly Linked List (2) Removing a node storing PVD

Page 47: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 47

class DLinkedList (1)

// Code Fragment 3.23 class DLinkedList { // doubly linked list public:

DLinkedList(); // constructor ~DLinkedList(); // destructor bool empty() const; // is list empty? const Elem& front() const; // get front element const Elem& back() const; // get back element void addFront(const Elem& e); // add to front of list void addBack(const Elem& e); // add to back of list void removeFront(); // remove from front void removeBack(); // remove from back

private: // local type definitions DNode* header; // list sentinels DNode* trailer;

protected: // local utilities void add(DNode* v, const Elem& e); // insert new node before v void remove(DNode* v); // remove node v

};

Page 48: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 48

class DLinkedList (2) DLinkedList:: DLinkedList() { // constructor

header = new DNode; // create sentinels trailer = new DNode; header->next = trailer; // have them point to each other trailer->prev = header;

} DLinkedList:: ~DLinkedList() { // destructor

while (!empty()) removeFront(); // remove all but sentinels

delete header; // remove the sentinels delete trailer;

} bool DLinkedList:: empty() const // is list empty? { return (header->next == trailer); } const Elem& DLinkedList:: front() const // get front element { return header->next->elem; } const Elem& DLinkedList:: back() const // get back element { return trailer->prev->elem; }

Page 49: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 49

class DLinkedList (3) // insert new node before v void DLinkedList::add(DNode* v, const Elem& e) {

DNode* u = new DNode; u->elem = e; // create a new node for e u->next = v; // link u in between v u->prev = v->prev; // ...and v->prev v->prev->next = v->prev = u;

} void DLinkedList::addFront(const Elem& e) // add to front of list {

add(header->next, e); } void DLinkedList::addBack(const Elem& e) // add to back of list {

add(trailer, e); }

Page 50: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 50

class DLinkedList (3) void DLinkedList::remove(DNode* v) { // remove node v

DNode* u = v->prev; // predecessor DNode* w = v->next; // successor u->next = w; // unlink v from list w->prev = u; delete v;

} void DLinkedList::removeFront() // remove from font {

remove(header->next); } void DLinkedList::removeBack() // remove from back {

remove(trailer->prev); }

Page 51: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 51

Class LinkedDeque (1)

typedef string Elem; // deque element type class LinkedDeque { // deque as doubly linked list public:

LinkedDeque(); // constructor int size() const; // number of items in the deque bool empty() const; // is the deque empty? const Elem& front() const throw(DequeEmpty); // the first element const Elem& back() const throw(DequeEmpty); // the last element void insertFront(const Elem& e); // insert new first element void insertBack(const Elem& e); // insert new last element void removeFront() throw(DequeEmpty); // remove first element void removeBack() throw(DequeEmpty); // remove last element

private: // member data DLinkedList D; // linked list of elements int n; // number of elements

};

Page 52: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 52

Class LinkedDeque (2) // insert new first element void LinkedDeque::insertFront(const Elem& e) { D.addFront(e); n++; } // insert new last element void LinkedDeque::insertBack(const Elem& e) { D.addBack(e); n++; } // remove first element void LinkedDeque::removeFront() throw(DequeEmpty) { if (empty()) throw DequeEmpty("removeFront of empty deque"); D.removeFront(); n--; } // remove last element void LinkedDeque::removeBack() throw(DequeEmpty) { if (empty()) throw DequeEmpty("removeBack of empty deque"); D.removeBack(); n--; }

Page 53: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 53

Adapters and Adapter Design Pattern

Class DequeStack typedef string Elem; // element type class DequeStack { // stack as a deque public: DequeStack(); // constructor int size() const; // number of elements bool empty() const; // is the stack empty? const Elem& top() const throw(StackEmpty); // the top element void push(const Elem& e); // push element onto stack void pop() throw(StackEmpty); // pop the stack private: LinkedDeque D; // deque of elements };

Page 54: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 54

Member functions of DequeStack DequeStack::DequeStack() // constructor : D() { } // number of elements int DequeStack::size() const { return D.size(); } // is the stack empty? bool DequeStack::empty() const { return D.empty(); } // the top element const Elem& DequeStack::top() const throw(StackEmpty) { if (empty()) throw StackEmpty("top of empty stack"); return D.front(); } // push element onto stack void DequeStack::push(const Elem& e) { D.insertFront(e); } // pop the stack void DequeStack::pop() throw(StackEmpty) { if (empty()) throw StackEmpty("pop of empty stack"); D.removeFront(); }

Page 55: DataStruct 5. Stacks, Queues, and Dequescontents.kocw.net/KOCW/document/2013/youngnam/YoungTak... · 2016. 9. 9. · Michael T. Goodrich, et. al, Data Structures and Algorithms in

Advanced Networking Tech. Lab. Yeungnam University (YU-ANTL)

O-O Programming & Data Structure Prof. Young-Tak Kim DS 5 - 55

DS-5.1 Projects P-5.1 DS-5.2 Projects P-5.10

Homework DS-5