A flat_multimap is a kind of associative container that supports equivalent keys (possibly containing multiple copies of the same key value) and provides for fast retrieval of values of another type T based on the keys. More...
#include <flat_map.hpp>
Public Types | |
typedef Key | key_type |
typedef T | mapped_type |
typedef std::pair< Key, T > | value_type |
typedef ::boost::container::allocator_traits < Allocator > | allocator_traits_type |
typedef boost::container::allocator_traits < Allocator >::pointer | pointer |
typedef boost::container::allocator_traits < Allocator >::const_pointer | const_pointer |
typedef boost::container::allocator_traits < Allocator >::reference | reference |
typedef boost::container::allocator_traits < Allocator >::const_reference | const_reference |
typedef boost::container::allocator_traits < Allocator >::size_type | size_type |
typedef boost::container::allocator_traits < Allocator >::difference_type | difference_type |
typedef Allocator | allocator_type |
typedef Compare | key_compare |
Public Member Functions | |
typedef | BOOST_CONTAINER_IMPDEF (Allocator) stored_allocator_type |
typedef | BOOST_CONTAINER_IMPDEF (value_compare_impl) value_compare |
typedef | BOOST_CONTAINER_IMPDEF (iterator_impl) iterator |
typedef | BOOST_CONTAINER_IMPDEF (const_iterator_impl) const _iterator |
typedef | BOOST_CONTAINER_IMPDEF (reverse_iterator_impl) reverse_iterator |
typedef | BOOST_CONTAINER_IMPDEF (const_reverse_iterator_impl) const _reverse_iterator |
typedef | BOOST_CONTAINER_IMPDEF (impl_value_type) movable_value_type |
flat_multimap () | |
Effects: Default constructs an empty flat_map. More... | |
flat_multimap (const Compare &comp, const allocator_type &a=allocator_type()) | |
Effects: Constructs an empty flat_multimap using the specified comparison object and allocator. More... | |
flat_multimap (const allocator_type &a) | |
Effects: Constructs an empty flat_multimap using the specified allocator. More... | |
template<class InputIterator > | |
flat_multimap (InputIterator first, InputIterator last, const Compare &comp=Compare(), const allocator_type &a=allocator_type()) | |
Effects: Constructs an empty flat_multimap using the specified comparison object and allocator, and inserts elements from the range [first ,last ). More... | |
template<class InputIterator > | |
flat_multimap (ordered_range_t, InputIterator first, InputIterator last, const Compare &comp=Compare(), const allocator_type &a=allocator_type()) | |
Effects: Constructs an empty flat_multimap using the specified comparison object and allocator, and inserts elements from the ordered range [first ,last). More... | |
flat_multimap (std::initializer_list< value_type > il, const Compare &comp=Compare(), const allocator_type &a=allocator_type()) | |
Effects: Constructs an empty flat_map using the specified comparison object and allocator, and inserts elements from the range [il.begin(), il.end()). More... | |
flat_multimap (ordered_range_t, std::initializer_list< value_type > il, const Compare &comp=Compare(), const allocator_type &a=allocator_type()) | |
Effects: Constructs an empty flat_multimap using the specified comparison object and allocator, and inserts elements from the ordered range [il.begin(), il.end()). More... | |
flat_multimap (const flat_multimap &x) | |
Effects: Copy constructs a flat_multimap. More... | |
flat_multimap (BOOST_RV_REF(flat_multimap) x) | |
Effects: Move constructs a flat_multimap. More... | |
flat_multimap (const flat_multimap &x, const allocator_type &a) | |
Effects: Copy constructs a flat_multimap using the specified allocator. More... | |
flat_multimap (BOOST_RV_REF(flat_multimap) x, const allocator_type &a) | |
Effects: Move constructs a flat_multimap using the specified allocator. More... | |
flat_multimap & | operator= (BOOST_COPY_ASSIGN_REF(flat_multimap) x) |
Effects: Makes *this a copy of x. More... | |
flat_multimap & | operator= (BOOST_RV_REF(flat_multimap) x) BOOST_CONTAINER_NOEXCEPT_IF(allocator_traits_type |
Effects: this->swap(x.get()). More... | |
flat_multimap & | operator= (std::initializer_list< value_type > il) |
Effects: Assign content of il to *this More... | |
allocator_type | get_allocator () const BOOST_CONTAINER_NOEXCEPT |
Effects: Returns a copy of the Allocator that was passed to the object's constructor. More... | |
stored_allocator_type & | get_stored_allocator () BOOST_CONTAINER_NOEXCEPT |
Effects: Returns a reference to the internal allocator. More... | |
const stored_allocator_type & | get_stored_allocator () const BOOST_CONTAINER_NOEXCEPT |
Effects: Returns a reference to the internal allocator. More... | |
iterator | begin () BOOST_CONTAINER_NOEXCEPT |
Effects: Returns an iterator to the first element contained in the container. More... | |
const_iterator | begin () const BOOST_CONTAINER_NOEXCEPT |
Effects: Returns a const_iterator to the first element contained in the container. More... | |
iterator | end () BOOST_CONTAINER_NOEXCEPT |
Effects: Returns an iterator to the end of the container. More... | |
const_iterator | end () const BOOST_CONTAINER_NOEXCEPT |
Effects: Returns a const_iterator to the end of the container. More... | |
reverse_iterator | rbegin () BOOST_CONTAINER_NOEXCEPT |
Effects: Returns a reverse_iterator pointing to the beginning of the reversed container. More... | |
const_reverse_iterator | rbegin () const BOOST_CONTAINER_NOEXCEPT |
Effects: Returns a const_reverse_iterator pointing to the beginning of the reversed container. More... | |
reverse_iterator | rend () BOOST_CONTAINER_NOEXCEPT |
Effects: Returns a reverse_iterator pointing to the end of the reversed container. More... | |
const_reverse_iterator | rend () const BOOST_CONTAINER_NOEXCEPT |
Effects: Returns a const_reverse_iterator pointing to the end of the reversed container. More... | |
const_iterator | cbegin () const BOOST_CONTAINER_NOEXCEPT |
Effects: Returns a const_iterator to the first element contained in the container. More... | |
const_iterator | cend () const BOOST_CONTAINER_NOEXCEPT |
Effects: Returns a const_iterator to the end of the container. More... | |
const_reverse_iterator | crbegin () const BOOST_CONTAINER_NOEXCEPT |
Effects: Returns a const_reverse_iterator pointing to the beginning of the reversed container. More... | |
const_reverse_iterator | crend () const BOOST_CONTAINER_NOEXCEPT |
Effects: Returns a const_reverse_iterator pointing to the end of the reversed container. More... | |
bool | empty () const BOOST_CONTAINER_NOEXCEPT |
Effects: Returns true if the container contains no elements. More... | |
size_type | size () const BOOST_CONTAINER_NOEXCEPT |
Effects: Returns the number of the elements contained in the container. More... | |
size_type | max_size () const BOOST_CONTAINER_NOEXCEPT |
Effects: Returns the largest possible size of the container. More... | |
size_type | capacity () const BOOST_CONTAINER_NOEXCEPT |
Effects: Number of elements for which memory has been allocated. More... | |
void | reserve (size_type cnt) |
Effects: If n is less than or equal to capacity(), this call has no effect. More... | |
void | shrink_to_fit () |
Effects: Tries to deallocate the excess of memory created More... | |
iterator | insert (const value_type &x) |
Effects: Inserts x and returns the iterator pointing to the newly inserted element. More... | |
iterator | insert (BOOST_RV_REF(value_type) x) |
Effects: Inserts a new value move-constructed from x and returns the iterator pointing to the newly inserted element. More... | |
iterator | insert (BOOST_RV_REF(impl_value_type) x) |
Effects: Inserts a new value move-constructed from x and returns the iterator pointing to the newly inserted element. More... | |
iterator | insert (const_iterator p, const value_type &x) |
Effects: Inserts a copy of x in the container. More... | |
iterator | insert (const_iterator p, BOOST_RV_REF(value_type) x) |
Effects: Inserts a value move constructed from x in the container. More... | |
iterator | insert (const_iterator p, BOOST_RV_REF(impl_value_type) x) |
Effects: Inserts a value move constructed from x in the container. More... | |
template<class InputIterator > | |
void | insert (InputIterator first, InputIterator last) |
Requires: first, last are not iterators into *this. More... | |
template<class InputIterator > | |
void | insert (ordered_range_t, InputIterator first, InputIterator last) |
Requires: first, last are not iterators into *this. More... | |
void | insert (std::initializer_list< value_type > il) |
Effects: inserts each element from the range [il.begin(), il.end()) . More... | |
void | insert (ordered_range_t, std::initializer_list< value_type > il) |
Requires: [il.begin(), il.end()) must be ordered according to the predicate. More... | |
iterator | erase (const_iterator p) |
Effects: Erases the element pointed to by p. More... | |
size_type | erase (const key_type &x) |
Effects: Erases all elements in the container with key equivalent to x. More... | |
iterator | erase (const_iterator first, const_iterator last) |
Effects: Erases all the elements in the range [first, last). More... | |
void | swap (flat_multimap &x) |
Effects: Swaps the contents of *this and x. More... | |
void | clear () BOOST_CONTAINER_NOEXCEPT |
Effects: erase(a.begin(),a.end()). More... | |
key_compare | key_comp () const |
Effects: Returns the comparison object out of which a was constructed. More... | |
value_compare | value_comp () const |
Effects: Returns an object of value_compare constructed out of the comparison object. More... | |
iterator | find (const key_type &x) |
Returns: An iterator pointing to an element with the key equivalent to x, or end() if such an element is not found. More... | |
const_iterator | find (const key_type &x) const |
Returns: An const_iterator pointing to an element with the key equivalent to x, or end() if such an element is not found. More... | |
size_type | count (const key_type &x) const |
Returns: The number of elements with key equivalent to x. More... | |
iterator | lower_bound (const key_type &x) |
Returns: An iterator pointing to the first element with key not less than k, or a.end() if such an element is not found. More... | |
const_iterator | lower_bound (const key_type &x) const |
Returns: Allocator const iterator pointing to the first element with key not less than k, or a.end() if such an element is not found. More... | |
iterator | upper_bound (const key_type &x) |
Returns: An iterator pointing to the first element with key not less than x, or end() if such an element is not found. More... | |
const_iterator | upper_bound (const key_type &x) const |
Returns: Allocator const iterator pointing to the first element with key not less than x, or end() if such an element is not found. More... | |
std::pair< iterator, iterator > | equal_range (const key_type &x) |
Effects: Equivalent to std::make_pair(this->lower_bound(k), this->upper_bound(k)). More... | |
std::pair< const_iterator, const_iterator > | equal_range (const key_type &x) const |
Effects: Equivalent to std::make_pair(this->lower_bound(k), this->upper_bound(k)). More... | |
Friends | |
bool | operator== (const flat_multimap &x, const flat_multimap &y) |
Effects: Returns true if x and y are equal More... | |
bool | operator!= (const flat_multimap &x, const flat_multimap &y) |
Effects: Returns true if x and y are unequal More... | |
bool | operator< (const flat_multimap &x, const flat_multimap &y) |
Effects: Returns true if x is less than y More... | |
bool | operator> (const flat_multimap &x, const flat_multimap &y) |
Effects: Returns true if x is greater than y More... | |
bool | operator<= (const flat_multimap &x, const flat_multimap &y) |
Effects: Returns true if x is equal or less than y More... | |
bool | operator>= (const flat_multimap &x, const flat_multimap &y) |
Effects: Returns true if x is equal or greater than y More... | |
void | swap (flat_multimap &x, flat_multimap &y) |
Effects: x.swap(y) More... | |
A flat_multimap is a kind of associative container that supports equivalent keys (possibly containing multiple copies of the same key value) and provides for fast retrieval of values of another type T based on the keys.
The flat_multimap class supports random-access iterators.
A flat_multimap satisfies all of the requirements of a container and of a reversible container and of an associative container. For a flat_multimap<Key,T> the key_type is Key and the value_type is std::pair<Key,T> (unlike std::multimap<Key, T> which value_type is std::pair<const Key, T>).
Compare is the ordering function for Keys (e.g. std::less<Key>).
Allocator is the allocator to allocate the value_types (e.g. allocator< std::pair<Key, T> >).
flat_multimap is similar to std::multimap but it's implemented like an ordered vector. This means that inserting a new element into a flat_map invalidates previous iterators and references
Erasing an element invalidates iterators and references pointing to elements that come after (their keys are bigger) the erased element.
This container provides random-access iterators.
Key | is the key_type of the map |
Value | is the mapped_type |
Compare | is the ordering function for Keys (e.g. std::less<Key>). |
Allocator | is the allocator to allocate the value_type s (e.g. allocator< std::pair<Key, T> > ). |
typedef ::boost::container::allocator_traits<Allocator> boost::container::flat_multimap< Key, T, Compare, Allocator >::allocator_traits_type |
typedef Allocator boost::container::flat_multimap< Key, T, Compare, Allocator >::allocator_type |
typedef boost::container::allocator_traits<Allocator>::const_pointer boost::container::flat_multimap< Key, T, Compare, Allocator >::const_pointer |
typedef boost::container::allocator_traits<Allocator>::const_reference boost::container::flat_multimap< Key, T, Compare, Allocator >::const_reference |
typedef boost::container::allocator_traits<Allocator>::difference_type boost::container::flat_multimap< Key, T, Compare, Allocator >::difference_type |
typedef Compare boost::container::flat_multimap< Key, T, Compare, Allocator >::key_compare |
typedef Key boost::container::flat_multimap< Key, T, Compare, Allocator >::key_type |
typedef T boost::container::flat_multimap< Key, T, Compare, Allocator >::mapped_type |
typedef boost::container::allocator_traits<Allocator>::pointer boost::container::flat_multimap< Key, T, Compare, Allocator >::pointer |
typedef boost::container::allocator_traits<Allocator>::reference boost::container::flat_multimap< Key, T, Compare, Allocator >::reference |
typedef boost::container::allocator_traits<Allocator>::size_type boost::container::flat_multimap< Key, T, Compare, Allocator >::size_type |
typedef std::pair<Key, T> boost::container::flat_multimap< Key, T, Compare, Allocator >::value_type |
|
inline |
Effects: Default constructs an empty flat_map.
Complexity: Constant.
References boost::BOOST_STATIC_ASSERT(), and boost::program_options::value().
|
inlineexplicit |
Effects: Constructs an empty flat_multimap using the specified comparison object and allocator.
Complexity: Constant.
References boost::BOOST_STATIC_ASSERT(), and boost::program_options::value().
|
inlineexplicit |
Effects: Constructs an empty flat_multimap using the specified allocator.
Complexity: Constant.
References boost::BOOST_STATIC_ASSERT(), and boost::program_options::value().
|
inline |
Effects: Constructs an empty flat_multimap using the specified comparison object and allocator, and inserts elements from the range [first ,last ).
Complexity: Linear in N if the range [first ,last ) is already sorted using comp and otherwise N logN, where N is last - first.
References boost::BOOST_STATIC_ASSERT(), and boost::program_options::value().
|
inline |
Effects: Constructs an empty flat_multimap using the specified comparison object and allocator, and inserts elements from the ordered range [first ,last).
This function is more efficient than the normal range creation for ordered ranges.
Requires: [first ,last) must be ordered according to the predicate.
Complexity: Linear in N.
Note: Non-standard extension.
References boost::BOOST_STATIC_ASSERT(), and boost::program_options::value().
|
inline |
Effects: Constructs an empty flat_map using the specified comparison object and allocator, and inserts elements from the range [il.begin(), il.end()).
Complexity: Linear in N if the range [il.begin(), il.end()) is already sorted using comp and otherwise N logN, where N is last - first.
|
inline |
Effects: Constructs an empty flat_multimap using the specified comparison object and allocator, and inserts elements from the ordered range [il.begin(), il.end()).
This function is more efficient than the normal range creation for ordered ranges.
Requires: [il.begin(), il.end()) must be ordered according to the predicate.
Complexity: Linear in N.
Note: Non-standard extension.
References boost::BOOST_STATIC_ASSERT(), and boost::program_options::value().
|
inline |
Effects: Copy constructs a flat_multimap.
Complexity: Linear in x.size().
References boost::BOOST_STATIC_ASSERT(), and boost::program_options::value().
|
inline |
Effects: Move constructs a flat_multimap.
Constructs *this using x's resources.
Complexity: Constant.
Postcondition: x is emptied.
References boost::BOOST_STATIC_ASSERT(), and boost::program_options::value().
|
inline |
Effects: Copy constructs a flat_multimap using the specified allocator.
Complexity: Linear in x.size().
References boost::BOOST_STATIC_ASSERT(), and boost::program_options::value().
|
inline |
Effects: Move constructs a flat_multimap using the specified allocator.
Constructs *this using x's resources.
Complexity: Constant if a == x.get_allocator(), linear otherwise.
References boost::BOOST_STATIC_ASSERT(), and boost::program_options::value().
|
inline |
Effects: Returns an iterator to the first element contained in the container.
Throws: Nothing.
Complexity: Constant.
|
inline |
Effects: Returns a const_iterator to the first element contained in the container.
Throws: Nothing.
Complexity: Constant.
typedef boost::container::flat_multimap< Key, T, Compare, Allocator >::BOOST_CONTAINER_IMPDEF | ( | Allocator | ) |
typedef boost::container::flat_multimap< Key, T, Compare, Allocator >::BOOST_CONTAINER_IMPDEF | ( | value_compare_impl | ) |
typedef boost::container::flat_multimap< Key, T, Compare, Allocator >::BOOST_CONTAINER_IMPDEF | ( | iterator_impl | ) |
typedef boost::container::flat_multimap< Key, T, Compare, Allocator >::BOOST_CONTAINER_IMPDEF | ( | const_iterator_impl | ) | const |
typedef boost::container::flat_multimap< Key, T, Compare, Allocator >::BOOST_CONTAINER_IMPDEF | ( | reverse_iterator_impl | ) |
typedef boost::container::flat_multimap< Key, T, Compare, Allocator >::BOOST_CONTAINER_IMPDEF | ( | const_reverse_iterator_impl | ) | const |
typedef boost::container::flat_multimap< Key, T, Compare, Allocator >::BOOST_CONTAINER_IMPDEF | ( | impl_value_type | ) |
|
inline |
Effects: Number of elements for which memory has been allocated.
capacity() is always greater than or equal to size().
Throws: Nothing.
Complexity: Constant.
|
inline |
Effects: Returns a const_iterator to the first element contained in the container.
Throws: Nothing.
Complexity: Constant.
|
inline |
Effects: Returns a const_iterator to the end of the container.
Throws: Nothing.
Complexity: Constant.
|
inline |
|
inline |
Returns: The number of elements with key equivalent to x.
Complexity: log(size())+count(k)
|
inline |
Effects: Returns a const_reverse_iterator pointing to the beginning of the reversed container.
Throws: Nothing.
Complexity: Constant.
|
inline |
Effects: Returns a const_reverse_iterator pointing to the end of the reversed container.
Throws: Nothing.
Complexity: Constant.
|
inline |
Effects: Returns true if the container contains no elements.
Throws: Nothing.
Complexity: Constant.
|
inline |
Effects: Returns an iterator to the end of the container.
Throws: Nothing.
Complexity: Constant.
|
inline |
Effects: Returns a const_iterator to the end of the container.
Throws: Nothing.
Complexity: Constant.
|
inline |
Effects: Equivalent to std::make_pair(this->lower_bound(k), this->upper_bound(k)).
Complexity: Logarithmic
|
inline |
Effects: Equivalent to std::make_pair(this->lower_bound(k), this->upper_bound(k)).
Complexity: Logarithmic
|
inline |
Effects: Erases the element pointed to by p.
Returns: Returns an iterator pointing to the element immediately following q prior to the element being erased. If no such element exists, returns end().
Complexity: Linear to the elements with keys bigger than p
Note: Invalidates elements with keys not less than the erased element.
|
inline |
Effects: Erases all elements in the container with key equivalent to x.
Returns: Returns the number of erased elements.
Complexity: Logarithmic search time plus erasure time linear to the elements with bigger keys.
|
inline |
Effects: Erases all the elements in the range [first, last).
Returns: Returns last.
Complexity: size()*N where N is the distance from first to last.
Complexity: Logarithmic search time plus erasure time linear to the elements with bigger keys.
|
inline |
Returns: An iterator pointing to an element with the key equivalent to x, or end() if such an element is not found.
Complexity: Logarithmic.
|
inline |
Returns: An const_iterator pointing to an element with the key equivalent to x, or end() if such an element is not found.
Complexity: Logarithmic.
|
inline |
Effects: Returns a copy of the Allocator that was passed to the object's constructor.
Complexity: Constant.
|
inline |
Effects: Returns a reference to the internal allocator.
Throws: Nothing
Complexity: Constant.
Note: Non-standard extension.
|
inline |
Effects: Returns a reference to the internal allocator.
Throws: Nothing
Complexity: Constant.
Note: Non-standard extension.
|
inline |
Effects: Inserts x and returns the iterator pointing to the newly inserted element.
Complexity: Logarithmic search time plus linear insertion to the elements with bigger keys than x.
Note: If an element is inserted it might invalidate elements.
|
inline |
Effects: Inserts a new value move-constructed from x and returns the iterator pointing to the newly inserted element.
Complexity: Logarithmic search time plus linear insertion to the elements with bigger keys than x.
Note: If an element is inserted it might invalidate elements.
References boost::move().
|
inline |
Effects: Inserts a new value move-constructed from x and returns the iterator pointing to the newly inserted element.
Complexity: Logarithmic search time plus linear insertion to the elements with bigger keys than x.
Note: If an element is inserted it might invalidate elements.
References boost::move().
|
inline |
Effects: Inserts a copy of x in the container.
p is a hint pointing to where the insert should start to search.
Returns: An iterator pointing to the element with key equivalent to the key of x.
Complexity: Logarithmic search time (constant time if the value is to be inserted before p) plus linear insertion to the elements with bigger keys than x.
Note: If an element is inserted it might invalidate elements.
|
inline |
Effects: Inserts a value move constructed from x in the container.
p is a hint pointing to where the insert should start to search.
Returns: An iterator pointing to the element with key equivalent to the key of x.
Complexity: Logarithmic search time (constant time if the value is to be inserted before p) plus linear insertion to the elements with bigger keys than x.
Note: If an element is inserted it might invalidate elements.
References boost::move().
|
inline |
Effects: Inserts a value move constructed from x in the container.
p is a hint pointing to where the insert should start to search.
Returns: An iterator pointing to the element with key equivalent to the key of x.
Complexity: Logarithmic search time (constant time if the value is to be inserted before p) plus linear insertion to the elements with bigger keys than x.
Note: If an element is inserted it might invalidate elements.
References boost::move().
|
inline |
Requires: first, last are not iterators into *this.
Effects: inserts each element from the range [first,last) .
Complexity: At most N log(size()+N) (N is the distance from first to last) search time plus N*size() insertion time.
Note: If an element is inserted it might invalidate elements.
|
inline |
Requires: first, last are not iterators into *this.
Requires: [first ,last) must be ordered according to the predicate.
Effects: inserts each element from the range [first,last) if and only if there is no element with key equivalent to the key of that element. This function is more efficient than the normal range creation for ordered ranges.
Complexity: At most N log(size()+N) (N is the distance from first to last) search time plus N*size() insertion time.
Note: If an element is inserted it might invalidate elements.
Note: Non-standard extension.
|
inline |
Effects: inserts each element from the range [il.begin(), il.end()) .
Complexity: At most N log(size()+N) (N is the distance from first to last) search time plus N*size() insertion time.
Note: If an element is inserted it might invalidate elements.
|
inline |
Requires: [il.begin(), il.end()) must be ordered according to the predicate.
Effects: inserts each element from the range [il.begin(), il.end()) if and only if there is no element with key equivalent to the key of that element. This function is more efficient than the normal range creation for ordered ranges.
Complexity: At most N log(size()+N) (N is the distance from first to last) search time plus N*size() insertion time.
Note: If an element is inserted it might invalidate elements.
Note: Non-standard extension.
|
inline |
Effects: Returns the comparison object out of which a was constructed.
Complexity: Constant.
|
inline |
Returns: An iterator pointing to the first element with key not less than k, or a.end() if such an element is not found.
Complexity: Logarithmic
|
inline |
Returns: Allocator const iterator pointing to the first element with key not less than k, or a.end() if such an element is not found.
Complexity: Logarithmic
|
inline |
Effects: Returns the largest possible size of the container.
Throws: Nothing.
Complexity: Constant.
|
inline |
Effects: Makes *this a copy of x.
Complexity: Linear in x.size().
|
inline |
Effects: this->swap(x.get()).
Complexity: Constant.
References boost::move(), and boost::flyweights::x.
|
inline |
Effects: Assign content of il to *this
Complexity: Linear in il.size().
|
inline |
Effects: Returns a reverse_iterator pointing to the beginning of the reversed container.
Throws: Nothing.
Complexity: Constant.
|
inline |
Effects: Returns a const_reverse_iterator pointing to the beginning of the reversed container.
Throws: Nothing.
Complexity: Constant.
|
inline |
Effects: Returns a reverse_iterator pointing to the end of the reversed container.
Throws: Nothing.
Complexity: Constant.
|
inline |
Effects: Returns a const_reverse_iterator pointing to the end of the reversed container.
Throws: Nothing.
Complexity: Constant.
|
inline |
Effects: If n is less than or equal to capacity(), this call has no effect.
Otherwise, it is a request for allocation of additional memory. If the request is successful, then capacity() is greater than or equal to n; otherwise, capacity() is unchanged. In either case, size() is unchanged.
Throws: If memory allocation allocation throws or T's copy constructor throws.
Note: If capacity() is less than "cnt", iterators and references to to values might be invalidated.
|
inline |
Effects: Tries to deallocate the excess of memory created
Throws: If memory allocation throws, or T's copy constructor throws.
Complexity: Linear to size().
|
inline |
Effects: Returns the number of the elements contained in the container.
Throws: Nothing.
Complexity: Constant.
|
inline |
Effects: Swaps the contents of *this and x.
Throws: Nothing.
Complexity: Constant.
|
inline |
Returns: An iterator pointing to the first element with key not less than x, or end() if such an element is not found.
Complexity: Logarithmic
|
inline |
Returns: Allocator const iterator pointing to the first element with key not less than x, or end() if such an element is not found.
Complexity: Logarithmic
|
inline |
Effects: Returns an object of value_compare constructed out of the comparison object.
Complexity: Constant.
|
friend |
Effects: Returns true if x and y are unequal
Complexity: Linear to the number of elements in the container.
|
friend |
Effects: Returns true if x is less than y
Complexity: Linear to the number of elements in the container.
|
friend |
Effects: Returns true if x is equal or less than y
Complexity: Linear to the number of elements in the container.
|
friend |
Effects: Returns true if x and y are equal
Complexity: Linear to the number of elements in the container.
|
friend |
Effects: Returns true if x is greater than y
Complexity: Linear to the number of elements in the container.
|
friend |
Effects: Returns true if x is equal or greater than y
Complexity: Linear to the number of elements in the container.
|
friend |
Effects: x.swap(y)
Complexity: Constant.