- allocator_typeget_allocator()constnoexcept; - Эффекты: Возвращает копию распределителя, которая была передана конструктору объекта. - Сложность: Постоянная. 
- stored_allocator_type&get_stored_allocator()noexcept; - Эффекты: Возвращает ссылку на внутренний распределитель. - Бросает: Ничто - Сложность: Константа. - Примечание: Нестандартное расширение. 
- conststored_allocator_type&get_stored_allocator()constnoexcept; - Эффекты: Возвращает ссылку на внутренний распределитель. - Броски: Ничто - Сложность: Константа. - Примечание: Нестандартное расширение. 
- iteratorbegin()noexcept; - Эффекты: возвращает итератор к первому элементу, содержащемуся в контейнере. - Бросок: Ничего. - Сложность: Постоянная. 
- const_iteratorbegin()constnoexcept; - Эффекты: Возвращает const_iterator к первому элементу контейнера. - Бросок: Ничего. - Сложность: Постоянная. 
- iteratorend()noexcept; - Эффекты: Возвращает итератор в конец контейнера. - Бросает: Ничего. - Сложность: Постоянная. 
- <const_iteratorend()constnoexcept; >Эффекты: Возвращает const_iterator в конец контейнера. Бросает: Сложность: Постоянство. 
- reverse_iteratorrbegin()noexcept; - Эффекты: Возвращает обратный_iterator, указывающий на начало обратного контейнера. - Бросок: Ничего. - Сложность: Постоянная. 
- const_reverse_iteratorrbegin()constnoexcept; - Эффекты: Возвращает const_reverse_iterator, указывающий на начало обратного контейнера. - Бросок: Ничего. - Сложность: Постоянная. 
- <reverse_iteratorrend()noexcept; >Эффекты: Возвращает обратный_iterator, указывающий на конец обратного контейнера. Бросок: Ничего. Сложность: Постоянство. 
- const_reverse_iteratorrend()constnoexcept; - Эффекты: Возвращает const_reverse_iterator, указывающий на конец обратного контейнера. - Бросок: Ничего. - Сложность: Постоянно. 
- const_iteratorcbegin()constnoexcept; - Эффекты: Возвращает const_iterator к первому элементу контейнера. - Бросок: Ничего. - Сложность: Постоянная. 
- const_iteratorcend()constnoexcept; - Эффекты: Возвращает const_iterator в конец контейнера. - Бросок: Ничего. - Сложность: Постоянная. 
- const_reverse_iteratorcrbegin()constnoexcept; - Эффекты: Возвращает const_reverse_iterator, указывающий на начало обратного контейнера. - Бросает: Ничего. - Сложность: Постоянная. 
- const_reverse_iteratorcrend()constnoexcept; - Эффекты: Возвращает const_reverse_iterator, указывающий на конец обратного контейнера. - Бросает: Ничего. - Сложность: Постоянная. 
- boolempty()constnoexcept; - Эффекты: Возвращается, если контейнер не содержит элементов. - Бросок: Ничего. - Сложность: Постоянная. 
- size_typesize()constnoexcept; - Эффекты: Возвращает количество элементов, содержащихся в контейнере. - Бросает: Ничего. - Сложность: Постоянная. 
- size_typemax_size()constnoexcept; - Эффекты: Возвращает максимально возможный размер контейнера. - Бросок: Ничего. - Сложность: Постоянная. 
- size_typecapacity()constnoexcept; - Эффекты: Количество элементов, для которых выделена память. Вместимость () всегда больше или равна размеру (). - Бросок: Ничего. - Сложность: Постоянная. 
- voidreserve(size_typecnt); - Эффекты: Если n меньше или равно емкости(), этот вызов не имеет эффекта. В противном случае это запрос на выделение дополнительной памяти. Если запрос является успешным, то емкость () больше или равна n; в противном случае емкость () не изменяется. В любом случае размер() не изменяется. - Бросок: Если выделение памяти бросает, или конструктор копий Т бросает. - Примечание: Если емкость () меньше "cnt", итераторы и ссылки на значения могут быть признаны недействительными. 
- voidshrink_to_fit(); Эффекты: Пытается разобраться с избытком созданной памяти- Бросок: Если отбрасывает выделение памяти, или отбрасывает конструктор копий Т. - Сложность: Линейный размер(). 
- mapped_type&operator[](constkey_type&k); - Эффекты: Если в- flat_mapнет ключа, эквивалентного x, вставьте значение_type(x, T()) в- flat_map
 - . Возвращение: Ссылка на отображенный_тип, соответствующий x в *это. - Сложность: логарифмическая. 
- mapped_type&operator[](key_type&&k); - Эффекты: Если в- flat_mapнет ключа, эквивалентного x, то в- flat_mapвставляется значение_type(move(x), T()) (ключ построен с помощью перемещения)
 - . Возвращение: Ссылка на отображенный_тип, соответствующий x в *это. - Сложность: Логарифмическая. 
- template<typenameM>
 std::pair<iterator,bool>insert_or_assign(constkey_type&k,M&&obj); - Эффекты: Если ключ, эквивалентный k, уже существует в контейнере, назначает forward(obj) на отображенный_тип, соответствующий ключу k. Если ключ не существует, вставляет новое значение как бы путем вставки, конструируя его из value_type(k, forward(obj)). - Никакие итераторы или ссылки не являются недействительными. Если вставка является успешной, указатели и ссылки на элемент, полученный во время его удерживания в ручке узла, являются недействительными, а указатели и ссылки, полученные на этот элемент до его извлечения, становятся действительными. - Возвращение: Компонент bool является истинным, если вставка имела место, и ложным, если назначение имело место. Компонент итератора указывает на элемент, который был вставлен или обновлен. - Сложность: Логарифмический размер контейнера. 
- <template<typenameM>
 std::pair<iterator,bool>insert_or_assign(key_type&&k,M&&obj); >Эффекты: Если ключ, эквивалентный k, уже существует в контейнере, назначает forward(obj) на отображенный_тип, соответствующий ключу k. Если ключ не существует, вставляет новое значение как бы путем вставки, конструируя его из значения_type(k, move(obj)). Никакие итераторы или ссылки не являются недействительными. Если вставка является успешной, указатели и ссылки на элемент, полученный во время его удерживания в ручке узла, являются недействительными, а указатели и ссылки, полученные на этот элемент до его извлечения, становятся действительными. Возвращение: Компонент bool является истинным, если вставка имела место, и ложным, если назначение имело место. Компонент итератора указывает на элемент, который был вставлен или обновлен. Сложность: Логарифмический размер контейнера. 
- template<typenameM>
 iteratorinsert_or_assign(const_iteratorhint,constkey_type&k,M&&obj); - Эффекты: Если ключ, эквивалентный k, уже существует в контейнере, назначает forward(obj) на отображенный_тип, соответствующий ключу k. Если ключа не существует, вставляет новое значение как бы путем вставки, конструируя его из значения_type(k, forward(obj)) и нового элемента в контейнер как можно ближе к положению непосредственно перед подсказкой. - Никакие итераторы или ссылки не являются недействительными. Если вставка является успешной, указатели и ссылки на элемент, полученный во время его удерживания в ручке узла, являются недействительными, а указатели и ссылки, полученные на этот элемент до его извлечения, становятся действительными. - Возвращение: Компонент bool является истинным, если вставка имела место, и ложным, если назначение имело место. Компонент итератора указывает на элемент, который был вставлен или обновлен. - Сложность: Логарифмическая величина контейнера в целом, но амортизированная постоянная, если новый элемент вставлен непосредственно перед подсказкой. 
- template<typenameM>
 iteratorinsert_or_assign(const_iteratorhint,key_type&&k,M&&obj); - Эффекты: Если ключ, эквивалентный k, уже существует в контейнере, назначает forward(obj) на отображенный_тип, соответствующий ключу k. Если ключа не существует, вставляет новое значение как бы путем вставки, конструируя его из значения_type(k, move(obj)) и нового элемента в контейнер как можно ближе к положению непосредственно перед подсказкой. - Никакие итераторы или ссылки не являются недействительными. Если вставка является успешной, указатели и ссылки на элемент, полученный во время его удерживания в ручке узла, являются недействительными, а указатели и ссылки, полученные на этот элемент до его извлечения, становятся действительными. - Возвращение: Компонент bool является истинным, если вставка имела место, и ложным, если назначение имело место. Компонент итератора указывает на элемент, который был вставлен или обновлен. - Сложность: Логарифмическая величина контейнера в целом, но амортизированная постоянная, если новый элемент вставлен непосредственно перед подсказкой. 
- iteratornth(size_typen)noexcept; - Требует: размер() >= n. - Эффекты: Возвращает итератор к n-му элементу от начала контейнера. Возвращает конец(), если n == размер(). - Бросает: Ничего. - Сложность: Константа. - Примечание: Нестандартное расширение 
- const_iteratornth(size_typen)constnoexcept; - Требует: размер() >= n. - Эффекты: Возвращает const_iterator к n-му элементу с начала контейнера. Возвращает конец(), если n == размер(). - Бросок: Ничего. - Сложность: Константа. - Примечание: Нестандартное расширение 
- size_typeindex_of(iteratorp)noexcept; - Требуется: start()<= p<= end(). - Эффекты: Возвращает индекс элемента, указанный p и размером(), если p == конец(). - Бросок: Ничего. - Сложность: Константа. - Примечание: Нестандартное расширение 
- <size_typeindex_of(const_iteratorp)constnoexcept; >Требуется: start()<= p<= end(). Эффекты: Возвращает индекс элемента, указанный p и размером(), если p == конец(). Бросок: Ничего. Сложность: Константа. Примечание: Нестандартное расширение 
- T&at(constkey_type&k); - Возвращение: Ссылка на элемент, ключ которого эквивалентен x. - Броски: Объект исключения типа out_of_range, если такой элемент отсутствует. - Сложность: логарифмическая. 
- constT&at(constkey_type&k)const; - Возвращение: Ссылка на элемент, ключ которого эквивалентен x. - Броски: Объект исключения типа out_of_range, если такой элемент отсутствует. - Сложность: логарифмическая. 
- template<class...Args>std::pair<iterator,bool>emplace(Args&&...args); - Эффекты: Вставляется объект x типа T, построенный с помощью std::forward(args)... если и только если в контейнере нет элемента, эквивалентного ключу x. - Возвращается: Булевая составляющая возвращаемой пары верна тогда и только тогда, когда происходит вставка, и итераторная составляющая пары указывает на элемент с ключом, эквивалентным ключу x. - Сложность: Логарифмическое время поиска плюс линейная вставка в элементы с большими клавишами, чем x. - Примечание: Если элемент вставлен, это может сделать элементы недействительными. 
- <template<class...Args>
 iteratoremplace_hint(const_iteratorhint,Args&&...args); >Эффекты: Вставляется объект типа T, построенный с помощью std::forward(args)... в контейнер, если и только если в контейнере нет элемента с ключом, эквивалентным ключу x. p - подсказка, указывающая, где вставка должна начать поиск. Возвращение: Итератор, указывающий на элемент с ключом, эквивалентным ключу x. Сложность: Логарифмическое время поиска (постоянное, если x вставлено непосредственно перед p) плюс линейная вставка к элементам с большими клавишами, чем x. Примечание: Если элемент вставлен, это может сделать элементы недействительными. 
- template<class...Args>
 std::pair<iterator,bool>try_emplace(constkey_type&k,Args&&...args); - Требуется: value_type должен быть EmplaceConstructible на карте от piecewise_construct, forward_as_tuple(k), forward_as_tuple(forward(args)...) - Эффекты: Если карта уже содержит элемент, ключ которого эквивалентен k, то эффекта нет. В противном случае вставляется объект типа value_type, построенный с помощью piecewise_construct, forward_as_tuple(k), forward_as_tuple(forward(args)...). - Возврат: Булевая составляющая возвращаемой пары верна, если и только если вставка имела место. Возвращенный итератор указывает на элемент карты, ключ которого эквивалентен k. - Сложность: Логарифмический. 
- <template<class...Args>
 iteratortry_emplace(const_iteratorhint,constkey_type&k,
                      Args&&...args);>Требуется: value_type должен быть EmplaceConstructible в карте от piecewise_construct, forward_as_tuple(k), forward_as_tuple(forward(args)...) Эффекты: Если карта уже содержит элемент, ключ которого эквивалентен k, то эффекта нет. В противном случае вставляется объект типа value_type, построенный с помощью piecewise_construct, forward_as_tuple(k), forward_as_tuple(forward(args)...). Возврат: Возвращенный итератор указывает на элемент карты, ключ которого эквивалентен k. Сложность: Логарифмическая в целом, но амортизированная постоянная, если значение вставлено непосредственно перед п. 
- template<class...Args>
 std::pair<iterator,bool>try_emplace(key_type&&k,Args&&...args); - Требуется: value_type должен быть EmplaceConstructible в карте от piecewise_construct, forward_as_tuple(move(k)), forward_as_tuple(forward(args)...) - Эффекты: Если карта уже содержит элемент, ключ которого эквивалентен k, то эффекта нет. В противном случае вставляется объект типа value_type, построенный с помощью piecewise_construct, forward_as_tuple(move(k)), forward_as_tuple(forward(args)...). - Возврат: Булевая составляющая возвращаемой пары верна, если и только если вставка имела место. Возвращенный итератор указывает на элемент карты, ключ которого эквивалентен k. - Сложность: Логарифмический. 
- template<class...Args>
 iteratortry_emplace(const_iteratorhint,key_type&&k,Args&&...args); - Требуется: значение_типа должно быть EmplaceConstructible в карте от piecewise_construct, forward_as_tuple(move(k)), forward_as_tuple(forward(args)...) - Эффекты: Если карта уже содержит элемент, ключ которого эквивалентен k, то эффекта нет. В противном случае вставляется объект типа value_type, построенный с помощью piecewise_construct, forward_as_tuple(move(k)), forward_as_tuple(forward(args)...). - Возврат: Возвращенный итератор указывает на элемент карты, ключ которого эквивалентен k. - Сложность: Логарифмическая в целом, но амортизированная постоянная, если значение вставлено непосредственно перед p. 
- <std::pair<iterator,bool>insert(constvalue_type&x); >Эффекты: Вставляется x тогда и только тогда, когда в контейнере нет элемента с ключом, эквивалентным ключу x. Возвращается: Компонент болта возвращаемой пары верен тогда и только тогда, когда происходит вставка, и компонент итератора пары указывает на элемент с ключом, эквивалентным ключу x. Сложность: Логарифмическое время поиска плюс линейная вставка в элементы с большими клавишами, чем x. Примечание: Если элемент вставлен, это может сделать элементы недействительными. 
- std::pair<iterator,bool>insert(value_type&&x); - Эффекты: Вставляется новое значение_тип движения, построенное из пары, если и только если в контейнере нет элемента, эквивалентного ключу x. - Возврат: Булевая составляющая возвращаемой пары верна тогда и только тогда, когда происходит вставка, и итераторная составляющая пары указывает на элемент с ключом, эквивалентным ключу x. - Сложность: Логарифмическое время поиска плюс линейная вставка в элементы с большими клавишами, чем x. - Примечание: Если элемент вставлен, это может сделать элементы недействительными. 
- std::pair<iterator,bool>insert(movable_value_type&&x); - Эффекты: Вставляется новое значение_тип движения, построенное из пары, если и только если в контейнере нет элемента, эквивалентного ключу x. - Возврат: Булевая составляющая возвращаемой пары верна тогда и только тогда, когда происходит вставка, и итераторная составляющая пары указывает на элемент с ключом, эквивалентным ключу x. - Сложность: Логарифмическое время поиска плюс линейная вставка в элементы с большими клавишами, чем x. - Примечание: Если элемент вставлен, это может сделать элементы недействительными. 
- iteratorinsert(const_iteratorp,constvalue_type&x); - Эффекты: Вставляет копию x в контейнер, если и только если в контейнере нет элемента с ключом, эквивалентным ключу x. p - подсказка, указывающая, где вставка должна начать поиск. - Возвращение: Итератор, указывающий на элемент с ключом, эквивалентным ключу x. - Сложность: Логарифмическое время поиска (постоянное, если x вставлен непосредственно перед p) плюс линейная вставка к элементам с большими клавишами, чем x. - Примечание: Если элемент вставлен, это может сделать элементы недействительными. 
- iteratorinsert(const_iteratorp,value_type&&x); - Эффекты: Вставляет элемент, выполненный из x в контейнере. p - подсказка, указывающая, где вставка должна начать поиск. - Возвращение: Итератор, указывающий на элемент с ключом, эквивалентным ключу x. - Сложность: Логарифмическое время поиска (постоянное, если x вставлен непосредственно перед p) плюс линейная вставка к элементам с большими клавишами, чем x. - Примечание: Если элемент вставлен, это может сделать элементы недействительными. 
- <iteratorinsert(const_iteratorp,movable_value_type&&x); >Эффекты: Вставляет элемент, выполненный из x в контейнере. p - подсказка, указывающая, где вставка должна начать поиск. Возвращение: Итератор, указывающий на элемент с ключом, эквивалентным ключу x. Сложность: Логарифмическое время поиска (постоянное, если x вставлено непосредственно перед p) плюс линейная вставка к элементам с большими клавишами, чем x. Примечание: Если элемент вставлен, это может сделать элементы недействительными. 
- template<typenameInputIterator>
 voidinsert(InputIteratorfirst,InputIteratorlast); - Требует: первый, последний не являются итераторами в *это. - Эффекты: вставляет каждый элемент из диапазона [первый, последний], если и только если нет элемента с ключом, эквивалентным ключу этого элемента. - Сложность: Максимально N log(size()+N) (N - расстояние от первого до последнего) время поиска плюс N*size() время вставки. - Примечание: Если элемент вставлен, это может сделать элементы недействительными. 
- template<typenameInputIterator>
 voidinsert(ordered_unique_range_t,InputIteratorfirst,InputIteratorlast); - Требует: во-первых, последние не являются итераторами в *это. - Требует: [первый, последний] должен быть упорядочен в соответствии с предикатом и должен быть уникальными значениями. - Эффекты: вставляет каждый элемент из диапазона [первый, последний], если и только если нет элемента с ключом, эквивалентным ключу этого элемента. Эта функция более эффективна, чем создание нормального диапазона для упорядоченных диапазонов. - Сложность: Максимальное время поиска N log(size()+N) (N - расстояние от первого до последнего) плюс время вставки N*size(). - Примечание: Если элемент вставлен, это может сделать элементы недействительными. - Примечание: Нестандартное расширение. 
- voidinsert(std::initializer_list<value_type>il); - Эффекты: вставляет каждый элемент из диапазона [il.begin(), il.end()) если и только если нет элемента с ключом, эквивалентным ключу этого элемента. - Сложность: Максимально N log(size()+N) (N - расстояние от il.first() до il.end()) время поиска плюс N*size() время вставки. - Примечание: Если элемент вставлен, это может сделать элементы недействительными. 
- voidinsert(ordered_unique_range_t,std::initializer_list<value_type>il); - Требует: [il.begin(), il.end()) должны быть упорядочены в соответствии с предикатом и должны быть уникальными значениями. - Эффекты: вставляет каждый элемент из диапазона [il.begin(), il.end()) если и только если нет элемента с ключом, эквивалентным ключу этого элемента. Эта функция более эффективна, чем создание нормального диапазона для упорядоченных диапазонов. - Сложность: Максимальное время поиска N log(size()+N) (N - расстояние от первого до последнего) плюс время вставки N*size(). - Примечание: Если элемент вставлен, это может сделать элементы недействительными. - Примечание: Нестандартное расширение. 
- template<typenameC2>voidmerge(flat_map<Key,T,C2,Allocator>&source); - Требует: this->get_allocator() == source.get_allocator(). - Эффекты: Попытки извлечь каждый элемент из источника и вставить его в объект сравнения *это. Если в элементе есть ключ, эквивалентный ключу элемента из источника, то этот элемент не извлекается из источника. - Посткондиционер: Указатели и ссылки на переданные элементы источника относятся к тем же элементам, но как к членам этого. Итераторы, относящиеся к переданным элементам, будут продолжать ссылаться на их элементы, но теперь они ведут себя как итераторы в это, а не в источник. - Бросок: Ничего, если объект сравнения не бросит. - Сложность: N log(a.size() + N) (N имеет значение source.size()) 
- template<typenameC2>voidmerge(flat_map<Key,T,C2,Allocator>&&source); - Требует: this->get_allocator() == source.get_allocator(). - Эффекты: Попытки извлечь каждый элемент из источника и вставить его в объект сравнения *это. Если в элементе есть ключ, эквивалентный ключу элемента из источника, то этот элемент не извлекается из источника. - Посткондиционер: Указатели и ссылки на переданные элементы источника относятся к тем же элементам, но как к членам этого. Итераторы, относящиеся к переданным элементам, будут продолжать ссылаться на их элементы, но теперь они ведут себя как итераторы в это, а не в источник. - Бросок: Ничего, если объект сравнения не бросит. - Сложность: N log(a.size() + N) (N имеет значение source.size()) 
- <template<typenameC2>
 voidmerge(flat_multimap<Key,T,C2,Allocator>&source); >Требуется: это->get_allocator() == source.get_allocator(). Эффекты: Попытки извлечь каждый элемент из источника и вставить его в объект сравнения *это. Если в элементе есть ключ, эквивалентный ключу элемента из источника, то этот элемент не извлекается из источника. Посткондиционер: Указатели и ссылки на переданные элементы источника относятся к тем же элементам, но как к членам этого. Итераторы, относящиеся к переданным элементам, будут продолжать ссылаться на их элементы, но теперь они ведут себя как итераторы в это, а не в источник. Бросок: Ничего, если объект сравнения не бросает. Сложность: N log(a.size() + N) (N имеет значение source.size()) 
- template<typenameC2>
 voidmerge(flat_multimap<Key,T,C2,Allocator>&&source); - Требуется: это->get_allocator() == source.get_allocator(). - Эффекты: Попытки извлечь каждый элемент из источника и вставить его в объект сравнения *это. Если в элементе есть ключ, эквивалентный ключу элемента из источника, то этот элемент не извлекается из источника. - Посткондиционер: Указатели и ссылки на переданные элементы источника относятся к тем же элементам, но как к членам этого. Итераторы, относящиеся к переданным элементам, будут продолжать ссылаться на их элементы, но теперь они ведут себя как итераторы в это, а не в источник. - Бросок: Ничего, если объект сравнения не бросает. - Сложность: N log(a.size() + N) (N имеет значение source.size()) 
- <iteratorerase(const_iteratorp); >Эффекты: Стирает элемент, на который указывает p. Возвращает: Возвращает итератор, указывающий на элемент непосредственно после q перед стиранием элемента. Если такого элемента не существует, возвращается конец (). Сложность: Линейные элементы с ключами больше, чем p Примечание: Инвалидирует элементы ключами не меньше, чем стертый элемент. 
- size_typeerase(constkey_type&x); - Эффекты: Стирает все элементы в контейнере с ключом, эквивалентным x. - Возвращает: Возвращает число стертых элементов. - Сложность: Логарифмическое время поиска плюс время стирания линейно элементам с большими клавишами. 
- <iteratorerase(const_iteratorfirst,const_iteratorlast); >Эффекты: Стирает все элементы в диапазоне [первый, последний] Возвращает: Возвращается последним. Сложность: размер()*N, где N — расстояние от первого до последнего. Сложность: Логарифмическое время поиска плюс время стирания линейно элементам с большими клавишами. 
- voidswap(flat_map&x)noexcept(allocator_traits_type::is_always_equal::value&&boost::container::container_detail::is_nothrow_swappable<Compare>::value)); - Эффекты: Перемещает содержимое этого и x. - Бросает: Ничего. - Сложность: Постоянная. 
- voidclear()noexcept; - Эффекты: стирание (a.begin(),a.end()). - Посткондиция: размер() == 0. - : сложность: линейный размер(). 
- key_comparekey_comp()const; - Эффекты: Возвращает объект сравнения, из которого был построен объект сравнения. - Сложность: Постоянная. 
- <value_comparevalue_comp()const; >Эффекты: Возвращает объект value_compare, построенный из объекта сравнения. Сложность: Постоянно. 
- iteratorfind(constkey_type&x); - Возвращение: Итератор, указывающий на элемент с ключом, эквивалентным x, или конец(), если такой элемент не найден. - Сложность: Логарифмический. 
- const_iteratorfind(constkey_type&x)const; - Возвращение: Const_iterator указывает на элемент с ключом, эквивалентным x, или конец(), если такой элемент не найден. - Сложность: Логарифмический. 
- size_typecount(constkey_type&x)const; - Возвращение: Число элементов с ключом, эквивалентным x. - Сложность: log(size())+count(k) 
- iteratorlower_bound(constkey_type&x); - Возвращение: Итератор, указывающий на первый элемент ключом не менее k, или a.end(), если такой элемент не найден. - Сложность: Логарифмический. 
- const_iteratorlower_bound(constkey_type&x)const; - Возвращение: Конст-итератор, указывающий на первый элемент с ключом не менее k, или a.end(), если такой элемент не найден. - Сложность: Логарифмический. 
- iteratorupper_bound(constkey_type&x); - Возвращение: Итератор, указывающий на первый элемент с ключом не менее x, или конец(), если такой элемент не найден. - Сложность: Логарифмический. 
- const_iteratorupper_bound(constkey_type&x)const; - Возвращение: Конст-итератор, указывающий на первый элемент с ключом не менее x, или конец(), если такой элемент не найден. - Сложность: Логарифмический. 
- std::pair<iterator,iterator>equal_range(constkey_type&x); - Эффекты: Эквивалент std::make_pair(this->lower_bound(k), this->upper_bound(k)). - Сложность: Логарифмический. 
- <std::pair<const_iterator,const_iterator>
equal_range(constkey_type&x)const; >Эффекты: Эквивалент std::make_pair(this->lower_bound(k), this->upper_bound(k)). Сложность: Логарифмический.