2003 Prentice Hall, Inc. All rights reserved stack Adapter stack –Header –Insertions and deletions at one end –Last-in, first-out (LIFO) data structure –Can use vector, list, or deque (default) –Declarations stack > myStack; stack > myOtherStack; stack anotherStack; // default deque vector, list –Implementation of stack (default deque ) –Does not change behavior, just performance ( deque and vector fastest)
2003 Prentice Hall, Inc. All rights reserved. Outline 2 fig21_23.cpp (1 of 3) 1 // Fig : fig21_23.cpp 2 // Standard library adapter stack test program. 3 #include 4 5 using std::cout; 6 using std::endl; 7 8 #include // stack adapter definition 9 #include // vector class-template definition 10 #include // list class-template definition // popElements function-template prototype 13 template 14 void popElements( T &stackRef ); int main() 17 { 18 // stack with default underlying deque 19 std::stack intDequeStack; // stack with underlying vector 22 std::stack > intVectorStack; // stack with underlying list 25 std::stack > intListStack; 26 Create stacks with various implementations.
2003 Prentice Hall, Inc. All rights reserved. Outline 3 fig21_23.cpp (2 of 3) 27 // push the values 0-9 onto each stack 28 for ( int i = 0; i < 10; ++i ) { 29 intDequeStack.push( i ); 30 intVectorStack.push( i ); 31 intListStack.push( i ); } // end for // display and remove elements from each stack 36 cout << "Popping from intDequeStack: "; 37 popElements( intDequeStack ); 38 cout << "\nPopping from intVectorStack: "; 39 popElements( intVectorStack ); 40 cout << "\nPopping from intListStack: "; 41 popElements( intListStack ); cout << endl; return 0; } // end main 48 Use member function push.
2003 Prentice Hall, Inc. All rights reserved. Outline 4 fig21_23.cpp (3 of 3) fig21_23.cpp output (1 of 1) 49 // pop elements from stack object to which stackRef refers 50 template 51 void popElements( T &stackRef ) 52 { 53 while ( !stackRef.empty() ) { 54 cout << stackRef.top() << ' '; // view top element 55 stackRef.pop(); // remove top element } // end while } // end function popElements Popping from intDequeStack: Popping from intVectorStack: Popping from intListStack:
2003 Prentice Hall, Inc. All rights reserved queue Adapter queue –Header –Insertions at back, deletions at front –First-in-first-out (FIFO) data structure –Implemented with list or deque (default) std::queue values; Functions –push( element ) Same as push_back, add to end –pop( element ) Implemented with pop_front, remove from front –empty() –size()
2003 Prentice Hall, Inc. All rights reserved. Outline 6 fig21_24.cpp (1 of 2) 1 // Fig : fig21_24.cpp 2 // Standard library adapter queue test program. 3 #include 4 5 using std::cout; 6 using std::endl; 7 8 #include // queue adapter definition 9 10 int main() 11 { 12 std::queue values; // push elements onto queue values 15 values.push( 3.2 ); 16 values.push( 9.8 ); 17 values.push( 5.4 ); cout << "Popping from values: "; while ( !values.empty() ) { 22 cout << values.front() << ' '; // view front element 23 values.pop(); // remove element } // end while 26 Create queue, add values using push.
2003 Prentice Hall, Inc. All rights reserved. Outline 7 fig21_24.cpp (2 of 2) fig21_24.cpp output (1 of 1) 27 cout << endl; return 0; } // end main Popping from values:
2003 Prentice Hall, Inc. All rights reserved priority_queue Adapter priority_queue –Header –Insertions happen in sorted order, deletions from front –Implemented with vector (default) or deque –Highest priority element always removed first Heapsort algorithm puts largest elements at front less default, programmer can specify other comparator –Functions push(value), pop(value) top() –View top element size() empty()
2003 Prentice Hall, Inc. All rights reserved. Outline 9 fig21_25.cpp (1 of 2) 1 // Fig : fig21_25.cpp 2 // Standard library adapter priority_queue test program. 3 #include 4 5 using std::cout; 6 using std::endl; 7 8 #include // priority_queue adapter definition 9 10 int main() 11 { 12 std::priority_queue priorities; // push elements onto priorities 15 priorities.push( 3.2 ); 16 priorities.push( 9.8 ); 17 priorities.push( 5.4 ); cout << "Popping from priorities: "; while ( !priorities.empty() ) { 22 cout << priorities.top() << ' '; // view top element 23 priorities.pop(); // remove top element } // end while 26 Create priority queue.Insert items using push. When using pop, highest priority (largest) items removed first.
2003 Prentice Hall, Inc. All rights reserved. Outline 10 fig21_25.cpp (2 of 2) fig21_25.cpp output (1 of 1) 27 cout << endl; return 0; } // end main Popping from priorities:
2003 Prentice Hall, Inc. All rights reserved Algorithms Before STL –Class libraries incompatible among vendors –Algorithms built into container classes STL separates containers and algorithms –Easier to add new algorithms –More efficient, avoids virtual function calls –
2003 Prentice Hall, Inc. All rights reserved fill, fill_n, generate and generate_n Functions to change containers –fill(iterator1, iterator2, value); Sets range of elements to value –fill_n(iterator1, n, value); Sets n elements to value, starting at iterator1 –generate(iterator1, iterator2, function); Like fill, but calls function to set each value –generate(iterator1, quantity, function) Like fill_n, ""
2003 Prentice Hall, Inc. All rights reserved. Outline 13 fig21_26.cpp (1 of 3) 1 // Fig : fig21_26.cpp 2 // Standard library algorithms fill, fill_n, generate 3 // and generate_n. 4 #include 5 6 using std::cout; 7 using std::endl; 8 9 #include // algorithm definitions 10 #include // vector class-template definition char nextLetter(); // prototype int main() 15 { 16 std::vector chars( 10 ); 17 std::ostream_iterator output( cout, " " ); // fill chars with 5s 20 std::fill( chars.begin(), chars.end(), '5' ); cout << "Vector chars after filling with 5s:\n"; 23 std::copy( chars.begin(), chars.end(), output ); 24 Create vector of char s, to be used with various functions. Function fill.
2003 Prentice Hall, Inc. All rights reserved. Outline 14 fig21_26.cpp (2 of 3) 25 // fill first five elements of chars with As 26 std::fill_n( chars.begin(), 5, 'A' ); cout << "\n\nVector chars after filling five elements" 29 << " with As:\n"; 30 std::copy( chars.begin(), chars.end(), output ); // generate values for all elements of chars with nextLetter 33 std::generate( chars.begin(), chars.end(), nextLetter ); cout << "\n\nVector chars after generating letters A-J:\n"; 36 std::copy( chars.begin(), chars.end(), output ); // generate values for first five elements of chars 39 // with nextLetter 40 std::generate_n( chars.begin(), 5, nextLetter ); cout << "\n\nVector chars after generating K-O for the" 43 << " first five elements:\n"; 44 std::copy( chars.begin(), chars.end(), output ); cout << endl; return 0; } // end main Functions generate and generate_n use function nextLetter.
2003 Prentice Hall, Inc. All rights reserved. Outline 15 fig21_26.cpp (3 of 3) fig21_26.cpp output (1 of 1) // returns next letter in the alphabet (starts with A) 53 char nextLetter() 54 { 55 static char letter = 'A'; 56 return letter++; } // end function nextLetter Vector chars after filling with 5s: Vector chars after filling five elements with As: A A A A A Vector chars after generating letters A-J: A B C D E F G H I J Vector chars after generating K-O for the first five elements: K L M N O F G H I J