Download presentation
Presentation is loading. Please wait.
1
Quick Overview of STL STL = Standard Template Library Main concept : Container, Iterator Application : Linked list, Stack etc.
2
Container Types VectorRandom access to elements, efficient insertion at end vector Specialization of vector optimized for bool listEfficient insertion and removal throughout dequeRandom access, efficient insertion at front or back set Elements maintained in order, efficient test for inclusion, insertion, and removal multisetSet with repeated copies bitset Bit container templated on size rather than contained type map Access to values via keys, efficient insertion and removal multimapMap permitting duplicate keys stringCharacter container enhanced for string operations
3
Container Adaptors stackInsertions and removals only from top queueInsertions at back, removals from front priority queueEfficient access and removal of largest values
4
Selecting Container 1. How are values going to be accessed? If random access is important, then a vector or a deque should be used. If sequential access is sufficient, then one of the other structures may be suitable. 2. Is the order in which values are maintained in the collection important? There are a number of different ways values can be sequenced. If a strict ordering is important throughout the life of the container, then the set data structure is an obvious choice, as insertions into a set are automatically placed in order. If this ordering is important only at one point—for example, at the end of a long series of insertions—then it might be easier to place the values into a list or vector, and sort the resulting structure at the appropriate time. If the order that values are held in the structure is related to the order of insertion, then a stack, queue, or list may be the best choice. 3. Will the size of the structure vary widely over the course of execution? If so, a list or set might be the best choice. A vector or deque will continue to maintain a large buffer even after elements have been removed from the collection. Conversely, if the size of the collection remains relatively fixed, than a vector or deque will use less memory than a list or set holding the same number of elements. 4. Is it possible to estimate the size of the collection? The vector data structure provides a way to pre-allocate a block of memory of a given size, using the reserve() member function. This ability is not provided by the other containers.
5
Selecting Container (continues) 5. Is testing to see whether a value is contained in the collection a frequent operation? If so, then the set or map containers would be a good choice. Testing to see whether a value is contained in a set or map can be performed in a very small number of steps, logarithmic in the size of the container, whereas testing to see if a value is contained in one of the other types of collections might require comparing the value against every element being stored by the container. 6. Is the collection indexed? That is, can the collection be viewed as a series of key/value pairs? If the keys are integers between 0 and some upper limit, a vector or deque should be used. On the other hand, if the key values are some other ordered datatype—character, string, or user-defined type—the map container can be used. 7. Can values be related to each other? All values stored in any container provided by the Standard C++ Library must be able to test for equality against another similar value, but not all need to recognize the relational less-than operator. However, if values cannot be ordered using the relational less-than operator, they cannot be stored in a set or a map.
6
Selecting Container (continues) 8. Is finding and removing the largest value from the collection a frequent operation? If the answer is yes, the priority queue is the best data structure to use. 9. At what positions are values inserted into or removed from the structure? If values are inserted into or removed from the middle, then a list is the best choice. If values are inserted only at the beginning, a deque or a list is the preferred choice. If values are inserted or removed only at the end, a stack or queue may be a logical choice. 10. Is the merging of two or more sequences into one a frequent operation? If so, a set or a list would seem to be the best choice, depending whether the collection is maintained in order. Merging two sets is a very efficient operation. If the collections are not ordered, but the efficient splice() member function from class list can be used, then the list datatype is to be preferred, since this operation is not provided in the other containers.
Similar presentations
© 2024 SlidePlayer.com. Inc.
All rights reserved.