A MultiSSkipList is a Simple Associative Container, meaning that its value type, as well as its key type, is T.
 It is a Multiple Sorted Associative Container, meaning that two or more elements may be identical.
 It is a Associative Container LOGN, meaning that erasing of a single element is logarithmic.
 It is a Destructive Associative Container LOGN, meaning that destroying (delete folowed by erase) single element or a range of elements is done in logarithmic time.
 It is a Front Access Container meaning that the front of the list is available for retrieval, erasure and destruction in constant time.
 It is a Back Access Container LOGN meaning that the back of the list is available for retrieval, erasure and destruction in logarithmic time.
 
The Unique Sorted Associative Container and Multiple Sorted Associative Container requirements guarantee that inserting a range takes only linear time if the range is already sorted. Unfortunately, this has not been implemented yet and performs in the default nlogn time.
A MultiSSkipList has the important property that inserting a new element into a MultiSSkipList does not invalidate iterators that point to existing elements. Erasing an element from a MultiSSkipList also does not invalidate any iterators, except, of course, for iterators that actually point to the element that is being erased. 
A MultiSSkipList acts like a set in functionality though the performance requirements are different in a few places. 
A MultiSSkipList is a Reversible Container LOGN and uses a Bidirectional Iterator LOGN where decrementing takes logn time and incrementing takes constant time.
 The iterator is also LessThan Comparable. See MultiSSkipList::T0 for more info.
Defined in the custom header "CSSSkipList.h".
| Parameter | Description | Default | 
|---|---|---|
| T | The MultiSSkipList's key type and value type. This is also defined asMultiSSkipList::key_typeandMultiSSkipList::value_type.MultiSSkipList::mapped_typeis also defined to this value for convenience. | |
| Compare | The key comparison function, a Strict Weak Ordering whose argument type is key_type; it returnstrueif its first argument is less than its second argument, andfalseotherwise. This is also defined asmap::key_compareandmap::value_compare. | less<T> | 
| R | The MultiSSkipList's random number generator, used for selection of levels per node. | RNG | 
Simple Associative Container, Multiple Sorted Associative Container, Associative Container LOGN, Destructive Associative Container LOGN, Reversible Container LOGN, Front Access Container and Back Access Container LOGN
T is Assignable. Compare is a Strict Weak Ordering whose argument type is T. R is an RNG (is Default Constructible and supports rand() and drand()). None.
| Member | Where defined | Performance | Description | 
|---|---|---|---|
| value_type | Container | The type of object, T, stored in the container. | |
| key_type | Associative Container LOGN | The key type, T, associated with value_type. | |
| key_compare | Sorted Associative Container | Function object that compares two keys for ordering. | |
| value_compare | Sorted Associative Container | Function object that compares two values for ordering. | |
| container_type | MultiSSkipList | Type of this container | |
| pointer | Container | Pointer to T. | |
| reference | Container | Reference to T | |
| const_reference | Container | Const reference to T | |
| mapped_type | Simple Associative Container | A type identical to value_typeandT | |
| mapped_type_reference | Simple Associative Container | A type identical to reference | |
| const_mapped_type | Simple Associative Container | A type identical to const value_type | |
| const_mapped_type_reference | Simple Associative Container | A type identical to const reference | |
| size_type | Container | An unsigned integral type. | |
| difference_type | Container | A signed integral type. | |
| iterator | Container | Iterator used to iterate through the container's elements. [1] | |
| const_iterator | Container | Const iterator used to iterate through the container's elements. | |
| reverse_iterator | Reversible Container LOGN | Iterator used to iterate backwards through the container's elements. [1] | |
| const_reverse_iterator | Reversible Container LOGN | Const iterator used to iterate backwards through the container's elements. | |
| slpair | MultiSSkipList | std::pair< iterator, bool > | |
| iterator begin() | Container | O(1) | Returns an iteratorpointing to the beginning of the container. | 
| iterator end() | Container | O(1) | Returns an iteratorpointing to the end of the container. | 
| const_iterator begin() const | Container | O(1) | Returns a const_iteratorpointing to the beginning of the container. | 
| const_iterator end() const | Container | O(1) | Returns a const_iteratorpointing to the end of the container. | 
| reverse_iterator rbegin() | Reversible Container LOGN | O(1) | Returns a reverse_iteratorpointing to the beginning of the reversed container. | 
| reverse_iterator rend() | Reversible Container LOGN | O(1) | Returns a reverse_iteratorpointing to the end of the reversed container. | 
| const_reverse_iterator rbegin() const | Reversible Container LOGN | O(1) | Returns a const_reverse_iteratorpointing to the beginning of the reversed container. | 
| const_reverse_iterator rend() const | Reversible Container LOGN | O(1) | Returns a const_reverse_iteratorpointing to the end of the reversed container. | 
| size_type size() const | Container | O(1) | Returns the size of the container. | 
| size_type max_size() const | Container | O(1) | Returns the largest possible size of the container. | 
| bool empty() const | Container | O(1) | trueif the container's size is0. | 
| key_compare key_comp() const | Sorted Associative Container | O(1) | Returns the key_compareobject used by the container. | 
| value_compare value_comp() const | Sorted Associative Container | O(1) | Returns the value_compareobject used by the container. | 
| MultiSSkipList() | Container | O(1) | Creates an empty container. Default probability of 25% and 8 levels. | 
| MultiSSkipList(size_type maxNodes) | MultiSSkipList | O(1) | Creates an empty container. Default probability of 25%. Maximum levels based on maxNodes. | 
| MultiSSkipList(double probability, size_type maxLevel) | MultiSSkipList | O(1) | Create an empty container with the specified probability and maximum levels. | 
| MultiSSkipList(const container_type &source) | Container | O(n*logn) | Copy constructor. Copies all elements along with probability and maximum levels. | 
| template<class InIt > | Multiple Sorted Associative Container | O(n*logn) | Creates a container with a copy of the range. Probability is 25% and maximum levels is 8. | 
| template<class InIt > | Multiple Sorted Associative Container w/ probability | O(n*logn) | Creates a container with the specified probability and maximum levels along with a copy of the range. | 
| template<class InIt > | Multiple Sorted Associative Container w/ probability | O(n*logn) | Creates a container with a copy of the range. Default probability of 25%. Maximum levels based on maxNodes. | 
| MultiSSkipList(const key_compare &comp) | Sorted Associative Container | O(1) | Creates an empty container, using compas thekey_compareobject. | 
| template<class InIt > | Multiple Sorted Associative Container | O(n*logn) | Creates a container with a copy of a range, using comp as the key_compare object. | 
| template<class InIt > | Multiple Sorted Associative Container /w probability | O(n*logn) | Creates a container with a copy of a range, using comp as the key_compare object. Container is created with specified probability and maximum level. | 
| template<class InIt > | Multiple Sorted Associative Container /w probability | O(n*logn) | Creates a container with a copy of a range, using comp as the key_compare object. Default probability of 25%. Maximum levels based on maxNodes. | 
| ~MultiSSkipList() | Container | O(n) | Destructor. Clears list. | 
| container_type& | Container | O(n) | The assignment operator | 
| void swap(container_type &right) | Container | O(1) | Swaps the contents of two containers. | 
| template<class InIt > | MultiSSkipList | O(n*logn) | Clears all elements and copies range into container. | 
| iterator insert(const value_type &val) | Multiple Associative Container | O(logn) | Inserts valinto the container. | 
| iterator insert(const iterator &where, | Multiple Sorted Associative Container | O(logn) | DO NOT USE THIS!!! Inserts valinto the container,using whereas a hint to where it will be inserted. | 
| template<class InIt > | Multiple Sorted Associative Container | O(n*logn) | Inserts a range into the container. Should be fixed to support O(n) when range is sorted. | 
| iterator erase(const iterator &where) | Associative Container LOGN | O(logn) | Erases the element pointed to by where. | 
| iterator destroy(const iterator &where) | Destructive Associative Container LOGN | O(logn) | Erases and deletes the element pointed to by where. | 
| size_type erase(const key_type &keyval) | Associative Container LOGN | O(logn) | Erases the element whose key is keyval. | 
| size_type destroy(const key_type &keyval) | Destructive Associative Container LOGN | O(logn) | Erases and deletes the element whose key is keyval. | 
| iterator erase(const iterator &first, const iterator &last) | Associative Container LOGN | O(n) | Erases all elements in a range. | 
| iterator destroy(const iterator &first, const iterator &last) | Destructive Associative Container LOGN | O(n) | Erases and deletes all elements in a range. | 
| void clear() | Associative Container LOGN | O(n) | Erases all of the elements. | 
| void destroy() | Destructive Associative Container LOGN | O(n) | Erases and deletes all of the elements. | 
| template<class Pr1 > | MultiSSkipList | O(n) | Erases all elements where pred(*where) is true. | 
| template<class Pr4 > | MultiSSkipList | O(n) | Destroys all elements where pred(*where) is true. | 
| void cut(const iterator &first, const iterator &last, | MultiSSkipList | O(logn) | Extract nodes in the specified range [first,last) into right. | 
| reference front() | Front Access Container | O(1) | Returns the first element. | 
| const_reference front() const | Front Access Container | O(1) | Returns the first element. | 
| reference back() | Back Access Container LOGN | O(logn) | Returns the last element. | 
| const_reference back() const | Back Access Container LOGN | O(logn) | Returns the last element. | 
| void pop_front() | Front Access Container | O(1C/logn) | Removes the first element. | 
| void destroy_front() | Front Access Container | O(1C/logn) | Removes and deletes the first pointer element. | 
| void pop_back() | Back Access Container LOGN | O(logn) | Removes the last element. | 
| void destroy_back() | Back Access Container LOGN | O(logn) | Removes and deletes the last pointer element. | 
| iterator find(const key_type &keyval) | Associative Container LOGN | O(logn) | Finds an element whose key is keyval. | 
| const_iterator find(const key_type &keyval) const | Associative Container LOGN | O(logn) | Finds an element whose key is keyval. | 
| size_type count(const key_type &keyval) const | Multiple Associative Container | O(logn) | Counts the number of elements whose key is keyval. | 
| iterator lower_bound(const key_type &keyval) | Sorted Associative Container | O(logn) | Finds the first element whose key is not less than keyval. | 
| const_iterator lower_bound(const key_type &keyval) const | Sorted Associative Container | O(logn) | Finds the first element whose key is not less than keyval. | 
| iterator upper_bound(const key_type &keyval) | Sorted Associative Container | O(logn) | Finds the first element whose key greater than keyval. | 
| const_iterator upper_bound(const key_type &keyval) const | Sorted Associative Container | O(logn) | Finds the first element whose key greater than keyval. | 
| std::pair< iterator, iterator > | Sorted Associative Container | O(logn) | Finds a range containing all elements whose key is keyval. | 
| std::pair< const_iterator, const_iterator > | Sorted Associative Container | O(logn) | Finds a range containing all elements whose key is keyval. | 
| bool operator==(const container&, | Forward Container | O(n) | Tests two maps for equality. This is a global function, not a member function. | 
| bool operator<(const container&, | Forward Container | O(n) | Lexicographical comparison. This is a global function, not a member function. | 
[1] MultiSSkipList::iterator is not a mutable iterator, because MultiSSkipList::value_type is not Assignable. That is, if i is of type MultiSSkipList::iterator and p is of type MultiSSkipList::value_type, then *i = p is not a valid expression. However, MultiSSkipList::iterator isn't a constant iterator either, because it can be used to modify the object that it points to for members that aren't used as part of the key. Using the same notation as above, i->member = p is a valid expression, but care must be taken to retain all original values related to the key in order to keep the list sorted. The same point applies to MultiSSkipList::reverse_iterator.
Iterator Overview, Bidirectional Iterator LOGN, Container, Simple Associative Container, Unique Sorted Associative Container, Multiple Sorted Associative Container, Associative Container, Associative Container LOGN, Sorted Associative Container, Destructive Associative Container LOGN, Pair Associative Container, Random Access Container LOGN Reversible Container, Reversible Container LOGN, Front Access Container, Back Access Container and Back Access Container LOGN
 1.7.3
 1.7.3