multimap
(STL/CLR)
Класс шаблона описывает объект, который управляет последовательностью элементов с двунаправленным доступом. Контейнер multimap
используется для управления последовательностью элементов в виде сбалансированного упорядоченного дерева узлов, каждого из которых хранится один элемент. Элемент состоит из ключа, для упорядочивания последовательности и сопоставленного значения, которое идет вдоль поездки.
В приведенном ниже описании то же самое, GValue
что и в следующем:
Microsoft::VisualC::StlClr::GenericPair<GKey, GMapped>
где:
GKey
то же Key
самое, что и если последний не является типом ссылок, в этом случае это Key^
GMapped
то же Mapped
самое, что и если последний не является типом ссылок, в этом случае это Mapped^
Синтаксис
template<typename Key,
typename Mapped>
ref class multimap
: public
System::ICloneable,
System::Collections::IEnumerable,
System::Collections::ICollection,
System::Collections::Generic::IEnumerable<GValue>,
System::Collections::Generic::ICollection<GValue>,
System::Collections::Generic::IList<GValue>,
Microsoft::VisualC::StlClr::ITree<Gkey, GValue>
{ ..... };
Параметры
Key
Тип ключевого компонента элемента в управляемой последовательности.
Mapped
Тип другого компонента элемента в управляемой последовательности.
Требования
Заголовок:<cliext/map>
Пространство имен: cliext
Объявления
Определение типа | Description |
---|---|
multimap::const_iterator |
Тип постоянного итератора для управляемой последовательности. |
multimap::const_reference |
Тип постоянной ссылки на элемент. |
multimap::const_reverse_iterator |
Тип постоянного обратного итератора для управляемой последовательности. |
multimap::difference_type |
Тип расстояния между двумя элементами (возможно, подписанным). |
multimap::generic_container |
Тип универсального интерфейса для контейнера. |
multimap::generic_iterator |
Тип итератора универсального интерфейса для контейнера. |
multimap::generic_reverse_iterator |
Тип обратного итератора для универсального интерфейса контейнера. |
multimap::generic_value |
Тип элемента универсального интерфейса для контейнера. |
multimap::iterator |
Тип итератора для управляемой последовательности. |
multimap::key_compare |
Делегат упорядочивания для двух ключей. |
multimap::key_type |
Тип ключа упорядочения. |
multimap::mapped_type |
Тип сопоставленного значения, связанного с каждым ключом. |
multimap::reference |
Тип ссылки на элемент. |
multimap::reverse_iterator |
Тип обратного итератора для управляемой последовательности. |
multimap::size_type |
Тип расстояния (не отрицательного) между двумя элементами. |
multimap::value_compare |
Делегат упорядочивания для двух значений элементов. |
multimap::value_type |
Тип элемента. |
Функция-член | Description |
---|---|
multimap::begin |
Задает начало управляемой последовательности. |
multimap::clear |
Удаляет все элементы. |
multimap::count |
Подсчитывает элементы, соответствующие указанному ключу. |
multimap::empty |
Проверяет отсутствие элементов. |
multimap::end |
Задает конец управляемой последовательности. |
multimap::equal_range |
Находит диапазон, соответствующий указанному ключу. |
multimap::erase |
Удаляет элементы в указанных позициях. |
multimap::find |
Определяет элемент, соответствующий указанному ключу. |
multimap::insert |
Добавляет элементы. |
multimap::key_comp |
Копирует делегат упорядочивания для двух ключей. |
multimap::lower_bound |
Находит начало диапазона, соответствующего указанному ключу. |
multimap::make_value |
Создает объект value. |
multimap::multimap |
Создает объект контейнера. |
multimap::rbegin |
Задает начало обратной управляемой последовательности. |
multimap::rend |
Задает конец обратной управляемой последовательности. |
multimap::size |
Подсчитывает количество элементов. |
multimap::swap |
Меняет местами содержимое двух контейнеров. |
multimap::to_array |
Копирует контролируемую последовательность в новый массив. |
multimap::upper_bound |
Находит конец диапазона, соответствующий указанному ключу. |
multimap::value_comp |
Копирует делегат упорядочивания для двух значений элементов. |
Operator | Description |
---|---|
multimap::operator= |
Заменяет управляемую последовательность. |
operator!= (multimap) |
Определяет, не равен ли multimap объект другому multimap объекту. |
operator< (multimap) |
Определяет, меньше ли multimap объект, чем другой multimap объект. |
operator<= (multimap) |
Определяет multimap , меньше ли объект или равен другому multimap объекту. |
operator== (multimap) |
Определяет, равен ли multimap объект другому multimap объекту. |
operator> (multimap) |
Определяет, больше ли multimap объект, чем другой multimap объект. |
operator>= (multimap) |
Определяет multimap , больше ли объект или равен другому multimap объекту. |
Интерфейсы
Интерфейс | Description |
---|---|
ICloneable | Дублировать объект. |
IEnumerable | Последовательность элементов. |
ICollection | Обслуживание группы элементов. |
IEnumerable<T> | Последовательность с помощью типизированных элементов. |
ICollection<T> | Сохраняйте группу типизированных элементов. |
ITree<Key, Value> |
Обслуживание универсального контейнера. |
Замечания
Объект выделяет и освобождает хранилище для последовательности, который он управляет как отдельные узлы. Он вставляет элементы в сбалансированное дерево , которое он сохраняет, изменяя связи между узлами, никогда не копируя содержимое одного узла в другой. Это означает, что вы можете свободно вставлять и удалять элементы без нарушения оставшихся элементов.
Объект упорядочивает последовательность, которую он управляет, вызывая сохраненный объект делегата типа multimap::key_compare
. При создании мультикарты можно указать сохраненный объект делегата; Если не указан объект делегата, по умолчанию используется сравнение operator<(key_type, key_type)
. Доступ к этому хранимой объекту выполняется путем вызова функции-члена multimap::key_comp
.
Такой объект делегата должен навязать строгое слабое упорядочение для ключей типа multimap::key_type
. Это означает, что для всех двух ключей X
и Y
:
key_comp()(X, Y)
возвращает один и тот же логический результат для каждого вызова.
Если key_comp()(X, Y)
значение имеет значение true, то key_comp()(Y, X)
должно быть false.
Если key_comp()(X, Y)
это правда, то X
, как говорят, будет упорядочено раньше Y
.
Если !key_comp()(X, Y) && !key_comp()(Y, X)
это правда, то X
и Y
говорят, что имеет эквивалентный порядок.
Для любого элемента X
, предшествующего Y
управляемой последовательности, key_comp()(Y, X)
имеет значение false. (Для объекта делегата по умолчанию ключи никогда не уменьшались.) В отличие от сопоставления классов шаблонов (STL/CLR), объект класса multimap
шаблона не требует, чтобы ключи для всех элементов были уникальными. (Два или более ключей могут иметь эквивалентный порядок.)
Каждый элемент содержит отдельный ключ и сопоставленное значение. Последовательность представлена таким образом, чтобы разрешить поиск, вставку и удаление произвольного элемента в логарифмическом времени. То есть количество операций пропорционально логарифму числа элементов в последовательности. Кроме того, при вставке элемента не выполняется итератор, а удаление элемента делает недопустимым только те итераторы, которые указывают на удаленный элемент.
Поддерживает multimap
двунаправленные итераторы, что означает, что можно переходить к смежным элементам с учетом итератора, обозначающего элемент в управляемой последовательности. Специальный головной узел соответствует итератору, возвращаемого end()
. Этот итератор можно уменьшать, чтобы достичь последнего элемента в управляемой последовательности, если он присутствует. Вы можете увеличить multimap
итератор для достижения головного узла, а затем сравнить его с равным end()
. Но вы не можете разыменовать итератор, возвращенный end()
.
Нельзя ссылаться на элемент непосредственно с учетом его числовой multimap
позиции. Для этого требуется итератор случайного доступа.
Итератор multimap
сохраняет дескриптор на связанный multimap
узел, который, в свою очередь, сохраняет дескриптор в связанном контейнере. Итераторы можно использовать только с связанными объектами контейнеров. Итератор multimap
остается допустимым до тех пор, пока связанный multimap
узел связан с несколькими картами. Кроме того, допустимый итератор является деreferencable. Его можно использовать для доступа или изменения значения элемента, указанного в нем, если оно не равно end()
.
Удаление или удаление элемента вызывает деструктор для его сохраненного значения. Удаление контейнера удаляет все элементы. Таким образом, контейнер, тип элемента которого является классом ссылок, гарантирует, что никакие элементы не выходят из контейнера. Однако контейнер дескрипторов не уничтожает его элементы.
Участники
multimap::begin
Задает начало управляемой последовательности.
Синтаксис
iterator begin();
Замечания
Функция-член возвращает двунаправленный итератор, указывающий первый элемент управляемой последовательности или только за пределами пустой последовательности. Он используется для получения итератора, который обозначает current
начало управляемой последовательности, но его состояние может измениться, если длина управляемой последовательности изменяется.
Пример
// cliext_multimap_begin.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// inspect first two items
Mymultimap::iterator it = c1.begin();
System::Console::WriteLine("*begin() = [{0} {1}]",
it->first, it->second);
++it;
System::Console::WriteLine("*++begin() = [{0} {1}]",
it->first, it->second);
return (0);
}
[a 1] [b 2] [c 3]
*begin() = [a 1]
*++begin() = [b 2]
multimap::clear
Удаляет все элементы.
Синтаксис
void clear();
Замечания
Функция-член фактически вызывает erase(begin(), end())
. Используйте его, чтобы убедиться, что управляемая последовательность пуста.
Пример
// cliext_multimap_clear.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// clear the container and reinspect
c1.clear();
System::Console::WriteLine("size() = {0}", c1.size());
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
// display contents " [a 1] [b 2]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
c1.clear();
System::Console::WriteLine("size() = {0}", c1.size());
return (0);
}
[a 1] [b 2] [c 3]
size() = 0
[a 1] [b 2]
size() = 0
multimap::const_iterator
Тип постоянного итератора для управляемой последовательности.
Синтаксис
typedef T2 const_iterator;
Замечания
Тип описывает объект неопределенного типа T2
, который может служить двунаправленным итератором постоянной двунаправленной последовательности.
Пример
// cliext_multimap_const_iterator.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
Mymultimap::const_iterator cit = c1.begin();
for (; cit != c1.end(); ++cit)
System::Console::Write("[{0} {1}] ", cit->first, cit->second);
System::Console::WriteLine();
return (0);
}
[a 1] [b 2] [c 3]
multimap::const_reference
Тип постоянной ссылки на элемент.
Синтаксис
typedef value_type% const_reference;
Замечания
Тип описывает константную ссылку на элемент.
Пример
// cliext_multimap_const_reference.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
Mymultimap::const_iterator cit = c1.begin();
for (; cit != c1.end(); ++cit)
{ // get a const reference to an element
Mymultimap::const_reference cref = *cit;
System::Console::Write("[{0} {1}] ", cref->first, cref->second);
}
System::Console::WriteLine();
return (0);
}
[a 1] [b 2] [c 3]
multimap::const_reverse_iterator
Тип постоянного обратного итератора для управляемой последовательности.
Синтаксис
typedef T4 const_reverse_iterator;
Замечания
Тип описывает объект неопределенного типа T4
, который может служить константным обратным итератором для управляемой последовательности.
Пример
// cliext_multimap_const_reverse_iterator.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]" reversed
Mymultimap::const_reverse_iterator crit = c1.rbegin();
for (; crit != c1.rend(); ++crit)
System::Console::Write("[{0} {1}] ", crit->first, crit->second);
System::Console::WriteLine();
return (0);
}
[c 3] [b 2] [a 1]
multimap::count
Определяет количество элементов, соответствующих заданному ключу.
Синтаксис
size_type count(key_type key);
Параметры
key
Искомое значение ключа.
Замечания
Функция-член возвращает количество элементов в управляемой последовательности с эквивалентным порядком key
. Он используется для определения количества элементов, которые в настоящее время находятся в управляемой последовательности, соответствующей указанному ключу.
Пример
// cliext_multimap_count.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
System::Console::WriteLine("count(L'A') = {0}", c1.count(L'A'));
System::Console::WriteLine("count(L'b') = {0}", c1.count(L'b'));
System::Console::WriteLine("count(L'C') = {0}", c1.count(L'C'));
return (0);
}
[a 1] [b 2] [c 3]
count(L'A') = 0
count(L'b') = 1
count(L'C') = 0
multimap::difference_type
Типы подписанного расстояния между двумя элементами.
Синтаксис
typedef int difference_type;
Замечания
Тип описывает возможное отрицательное число элементов.
Пример
// cliext_multimap_difference_type.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// compute positive difference
Mymultimap::difference_type diff = 0;
for (Mymultimap::iterator it = c1.begin(); it != c1.end(); ++it)
++diff;
System::Console::WriteLine("end()-begin() = {0}", diff);
// compute negative difference
diff = 0;
for (Mymultimap::iterator it = c1.end(); it != c1.begin(); --it)
--diff;
System::Console::WriteLine("begin()-end() = {0}", diff);
return (0);
}
[a 1] [b 2] [c 3]
end()-begin() = 3
begin()-end() = -3
multimap::empty
Проверяет отсутствие элементов.
Синтаксис
bool empty();
Замечания
Эта функция-член возвращает значение true для пустой управляемой последовательности. Это эквивалентно size() == 0
. Он используется для проверки того, является ли он multimap
пустым.
Пример
// cliext_multimap_empty.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
System::Console::WriteLine("size() = {0}", c1.size());
System::Console::WriteLine("empty() = {0}", c1.empty());
// clear the container and reinspect
c1.clear();
System::Console::WriteLine("size() = {0}", c1.size());
System::Console::WriteLine("empty() = {0}", c1.empty());
return (0);
}
[a 1] [b 2] [c 3]
size() = 3
empty() = False
size() = 0
empty() = True
multimap::end
Задает конец управляемой последовательности.
Синтаксис
iterator end();
Замечания
Функция-член возвращает двунаправленный итератор, указывающий непосредственно за пределами управляемой последовательности. Он используется для получения итератора, который обозначает конец управляемой последовательности; его состояние не изменяется, если длина управляемой последовательности изменяется.
Пример
// cliext_multimap_end.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// inspect last two items
Mymultimap::iterator it = c1.end();
--it;
--it;
System::Console::WriteLine("*-- --end() = [{0} {1}]",
it->first, it->second);
++it;
System::Console::WriteLine("*--end() = [{0} {1}]",
it->first, it->second);
return (0);
}
[a 1] [b 2] [c 3]
*-- --end() = [b 2]
*--end() = [c 3]
multimap::equal_range
Находит диапазон, соответствующий указанному ключу.
Синтаксис
pair_iter_iter equal_range(key_type key);
Параметры
key
Искомое значение ключа.
Замечания
Метод возвращает пару итераторов. pair_iter_iter(lower_bound(key), upper_bound(key))
Он используется для определения диапазона элементов, которые в настоящее время находятся в управляемой последовательности, соответствующей указанному ключу.
Пример
// cliext_multimap_equal_range.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
typedef Mymultimap::pair_iter_iter Pairii;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// display results of failed search
Pairii pair1 = c1.equal_range(L'x');
System::Console::WriteLine("equal_range(L'x') empty = {0}",
pair1.first == pair1.second);
// display results of successful search
pair1 = c1.equal_range(L'b');
for (; pair1.first != pair1.second; ++pair1.first)
System::Console::Write("[{0} {1}] ",
pair1.first->first, pair1.first->second);
System::Console::WriteLine();
return (0);
}
[a 1] [b 2] [c 3]
equal_range(L'x') empty = True
[b 2]
multimap::erase
Удаляет элементы в указанных позициях.
Синтаксис
iterator erase(iterator where);
iterator erase(iterator first, iterator last);
bool erase(key_type key)
Параметры
first
Начало диапазона для удаления.
key
Значение ключа для удаления.
last
Конец диапазона для удаления.
where
Элемент для удаления.
Замечания
Первая функция-член удаляет элемент управляемой последовательности, на которую указывает where
, и возвращает итератор, указывающий первый элемент, оставшийся за пределами удаленного элемента, или end()
если такой элемент отсутствует. Он используется для удаления одного элемента.
Вторая функция-член удаляет элементы управляемой последовательности в диапазоне [first
, last
и возвращает итератор, указывающий первый элемент, оставшийся за пределами удаленных элементов, или end()
если такой элемент отсутствует. Он используется для удаления нуля или нескольких смежных элементов.
Третья функция-член удаляет любой элемент управляемой последовательности, ключ которой имеет эквивалентное упорядочивание key
, и возвращает количество удаленных элементов. Он используется для удаления и подсчета всех элементов, соответствующих указанному ключу.
Каждый элемент стирает время пропорционально логарифму числа элементов в управляемой последовательности.
Пример
// cliext_multimap_erase.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
cliext::multimap<wchar_t, int> c1;
c1.insert(cliext::multimap<wchar_t, int>::make_value(L'a', 1));
c1.insert(cliext::multimap<wchar_t, int>::make_value(L'b', 2));
c1.insert(cliext::multimap<wchar_t, int>::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (cliext::multimap<wchar_t, int>::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// erase an element and reinspect
cliext::multimap<wchar_t, int>::iterator it =
c1.erase(c1.begin());
System::Console::WriteLine("erase(begin()) = [{0} {1}]",
it->first, it->second);
// add elements and display " b c d e"
c1.insert(cliext::multimap<wchar_t, int>::make_value(L'd', 4));
c1.insert(cliext::multimap<wchar_t, int>::make_value(L'e', 5));
for each (cliext::multimap<wchar_t, int>::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// erase all but end
it = c1.end();
it = c1.erase(c1.begin(), --it);
System::Console::WriteLine("erase(begin(), end()-1) = [{0} {1}]",
it->first, it->second);
System::Console::WriteLine("size() = {0}", c1.size());
// erase end
System::Console::WriteLine("erase(L'x') = {0}", c1.erase(L'x'));
System::Console::WriteLine("erase(L'e') = {0}", c1.erase(L'e'));
return (0);
}
[a 1] [b 2] [c 3]
erase(begin()) = [b 2]
[b 2] [c 3] [d 4] [e 5]
erase(begin(), end()-1) = [e 5]
size() = 1
erase(L'x') = 0
erase(L'e') = 1
multimap::find
Определяет элемент, соответствующий указанному ключу.
Синтаксис
iterator find(key_type key);
Параметры
key
Искомое значение ключа.
Замечания
Если по крайней мере один элемент в управляемой последовательности имеет эквивалентное упорядочение, key
функция-член возвращает итератор, указывающий один из этих элементов; в противном случае возвращаетсяend()
. Он используется для поиска элемента в управляемой последовательности, которая соответствует указанному ключу.
Пример
// cliext_multimap_find.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
System::Console::WriteLine("find {0} = {1}",
L'A', c1.find(L'A') != c1.end());
Mymultimap::iterator it = c1.find(L'b');
System::Console::WriteLine("find {0} = [{1} {2}]",
L'b', it->first, it->second);
System::Console::WriteLine("find {0} = {1}",
L'C', c1.find(L'C') != c1.end());
return (0);
}
[a 1] [b 2] [c 3]
find A = False
find b = [b 2]
find C = False
multimap::generic_container
Тип универсального интерфейса для контейнера.
Синтаксис
typedef Microsoft::VisualC::StlClr::
ITree<GKey, GValue>
generic_container;
Замечания
Тип описывает универсальный интерфейс для этого класса контейнера шаблона.
Пример
// cliext_multimap_generic_container.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// construct a generic container
Mymultimap::generic_container^ gc1 = %c1;
for each (Mymultimap::value_type elem in gc1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// modify generic and display original
gc1->insert(Mymultimap::make_value(L'd', 4));
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// modify original and display generic
c1.insert(Mymultimap::make_value(L'e', 5));
for each (Mymultimap::value_type elem in gc1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
return (0);
}
[a 1] [b 2] [c 3]
[a 1] [b 2] [c 3]
[a 1] [b 2] [c 3] [d 4]
[a 1] [b 2] [c 3] [d 4] [e 5]
multimap::generic_iterator
Тип итератора для использования с универсальным интерфейсом для контейнера.
Синтаксис
typedef Microsoft::VisualC::StlClr::Generic::
ContainerBidirectionalIterator<generic_value>
generic_iterator;
Замечания
Тип описывает универсальный итератор, который можно использовать с универсальным интерфейсом для этого класса контейнеров шаблона.
Пример
// cliext_multimap_generic_iterator.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// construct a generic container
Mymultimap::generic_container^ gc1 = %c1;
for each (Mymultimap::value_type elem in gc1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// get an element and display it
Mymultimap::generic_iterator gcit = gc1->begin();
Mymultimap::generic_value gcval = *gcit;
System::Console::Write("[{0} {1}] ", gcval->first, gcval->second);
System::Console::WriteLine();
return (0);
}
[a 1] [b 2] [c 3]
[a 1] [b 2] [c 3]
[a 1]
multimap::generic_reverse_iterator
Тип обратного итератора для использования с универсальным интерфейсом для контейнера.
Синтаксис
typedef Microsoft::VisualC::StlClr::Generic::
ReverseRandomAccessIterator<generic_value>
generic_reverse_iterator;
Замечания
Тип описывает универсальный обратный итератор, который можно использовать с универсальным интерфейсом для этого класса контейнеров шаблона.
Пример
// cliext_multimap_generic_reverse_iterator.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// construct a generic container
Mymultimap::generic_container^ gc1 = %c1;
for each (Mymultimap::value_type elem in gc1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// get an element and display it
Mymultimap::generic_reverse_iterator gcit = gc1->rbegin();
Mymultimap::generic_value gcval = *gcit;
System::Console::WriteLine("[{0} {1}] ", gcval->first, gcval->second);
return (0);
}
[a 1] [b 2] [c 3]
[a 1] [b 2] [c 3]
[c 3]
multimap::generic_value
Тип элемента для использования с универсальным интерфейсом для контейнера.
Синтаксис
typedef GValue generic_value;
Замечания
Тип описывает объект типа GValue
, описывающий значение хранимого элемента для использования с универсальным интерфейсом для этого класса контейнера шаблона.
Пример
// cliext_multimap_generic_value.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// construct a generic container
Mymultimap::generic_container^ gc1 = %c1;
for each (Mymultimap::value_type elem in gc1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// get an element and display it
Mymultimap::generic_iterator gcit = gc1->begin();
Mymultimap::generic_value gcval = *gcit;
System::Console::WriteLine("[{0} {1}] ", gcval->first, gcval->second);
return (0);
}
[a 1] [b 2] [c 3]
[a 1] [b 2] [c 3]
[a 1]
multimap::insert
Добавляет элементы.
Синтаксис
iterator insert(value_type val);
iterator insert(iterator where, value_type val);
template<typename InIter>
void insert(InIter first, InIter last);
void insert(System::Collections::Generic::IEnumerable<value_type>^ right);
Параметры
first
Начало диапазона для вставки.
last
Конец диапазона для вставки.
right
Перечисление для вставки.
val
Значение ключа для вставки.
where
Где в контейнере для вставки (только подсказка).
Замечания
Каждая из функций-членов вставляет последовательность, указанную оставшимися операндами.
Первая функция-член вставляет элемент со значением val
и возвращает итератор, указывающий только что вставленный элемент. Он используется для вставки одного элемента.
Вторая функция-член вставляет элемент со значением val
, используя where
в качестве указания (для повышения производительности) и возвращает итератор, указывающий только что вставленный элемент. Вы используете его для вставки одного элемента, который может находиться рядом с элементом, который вы знаете.
Третья функция-член вставляет последовательность [first
, last
). Он используется для вставки нуля или нескольких элементов, скопированных из другой последовательности.
Четвертая функция-член вставляет последовательность, указанную параметром right
. Он используется для вставки последовательности, описанной перечислителем.
Каждое вставка элемента занимает время пропорционально логарифму числа элементов в управляемой последовательности. Вставка может происходить в амортизированном времени константы, однако при указании, обозначаемом элементом рядом с точкой вставки.
Пример
// cliext_multimap_insert.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// insert a single value, unique and duplicate
Mymultimap::iterator it =
c1.insert(Mymultimap::make_value(L'x', 24));
System::Console::WriteLine("insert([L'x' 24]) = [{0} {1}]",
it->first, it->second);
it = c1.insert(Mymultimap::make_value(L'b', 2));
System::Console::WriteLine("insert([L'b' 2]) = [{0} {1}]",
it->first, it->second);
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// insert a single value with hint
it = c1.insert(c1.begin(), Mymultimap::make_value(L'y', 25));
System::Console::WriteLine("insert(begin(), [L'y' 25]) = [{0} {1}]",
it->first, it->second);
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// insert an iterator range
Mymultimap c2;
it = c1.end();
c2.insert(c1.begin(), --it);
for each (Mymultimap::value_type elem in c2)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// insert an enumeration
Mymultimap c3;
c3.insert( // NOTE: cast is not needed
(System::Collections::Generic::
IEnumerable<Mymultimap::value_type>^)%c1);
for each (Mymultimap::value_type elem in c3)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
return (0);
}
[a 1] [b 2] [c 3]
insert([L'x' 24]) = [x 24]
insert([L'b' 2]) = [b 2]
[a 1] [b 2] [b 2] [c 3] [x 24]
insert(begin(), [L'y' 25]) = [y 25]
[a 1] [b 2] [b 2] [c 3] [x 24] [y 25]
[a 1] [b 2] [b 2] [c 3] [x 24]
[a 1] [b 2] [b 2] [c 3] [x 24] [y 25]
multimap::iterator
Тип итератора для управляемой последовательности.
Синтаксис
typedef T1 iterator;
Замечания
Тип описывает объект неопределенного типа T1
, который может служить двунаправленным итератором управляемой последовательности.
Пример
// cliext_multimap_iterator.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
Mymultimap::iterator it = c1.begin();
for (; it != c1.end(); ++it)
System::Console::Write("[{0} {1}] ", it->first, it->second);
System::Console::WriteLine();
return (0);
}
[a 1] [b 2] [c 3]
multimap::key_comp
Копирует делегат упорядочивания для двух ключей.
Синтаксис
key_compare^key_comp();
Замечания
Функция-член возвращает делегат упорядочивания, используемый для упорядочивания управляемой последовательности. Вы используете его для сравнения двух ключей.
Пример
// cliext_multimap_key_comp.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
Mymultimap::key_compare^ kcomp = c1.key_comp();
System::Console::WriteLine("compare(L'a', L'a') = {0}",
kcomp(L'a', L'a'));
System::Console::WriteLine("compare(L'a', L'b') = {0}",
kcomp(L'a', L'b'));
System::Console::WriteLine("compare(L'b', L'a') = {0}",
kcomp(L'b', L'a'));
System::Console::WriteLine();
// test a different ordering rule
Mymultimap c2 = cliext::greater<wchar_t>();
kcomp = c2.key_comp();
System::Console::WriteLine("compare(L'a', L'a') = {0}",
kcomp(L'a', L'a'));
System::Console::WriteLine("compare(L'a', L'b') = {0}",
kcomp(L'a', L'b'));
System::Console::WriteLine("compare(L'b', L'a') = {0}",
kcomp(L'b', L'a'));
return (0);
}
compare(L'a', L'a') = False
compare(L'a', L'b') = True
compare(L'b', L'a') = False
compare(L'a', L'a') = False
compare(L'a', L'b') = False
compare(L'b', L'a') = True
multimap::key_compare
Делегат упорядочивания для двух ключей.
Синтаксис
Microsoft::VisualC::StlClr::BinaryDelegate<GKey, GKey, bool>
key_compare;
Замечания
Тип является синонимом делегата, который определяет порядок его ключевых аргументов.
Пример
// cliext_multimap_key_compare.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
Mymultimap::key_compare^ kcomp = c1.key_comp();
System::Console::WriteLine("compare(L'a', L'a') = {0}",
kcomp(L'a', L'a'));
System::Console::WriteLine("compare(L'a', L'b') = {0}",
kcomp(L'a', L'b'));
System::Console::WriteLine("compare(L'b', L'a') = {0}",
kcomp(L'b', L'a'));
System::Console::WriteLine();
// test a different ordering rule
Mymultimap c2 = cliext::greater<wchar_t>();
kcomp = c2.key_comp();
System::Console::WriteLine("compare(L'a', L'a') = {0}",
kcomp(L'a', L'a'));
System::Console::WriteLine("compare(L'a', L'b') = {0}",
kcomp(L'a', L'b'));
System::Console::WriteLine("compare(L'b', L'a') = {0}",
kcomp(L'b', L'a'));
return (0);
}
compare(L'a', L'a') = False
compare(L'a', L'b') = True
compare(L'b', L'a') = False
compare(L'a', L'a') = False
compare(L'a', L'b') = False
compare(L'b', L'a') = True
multimap::key_type
Тип ключа упорядочения.
Синтаксис
typedef Key key_type;
Замечания
Этот тип является синонимом для параметра шаблона Key
.
Пример
// cliext_multimap_key_type.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]" using key_type
for (Mymultimap::iterator it = c1.begin(); it != c1.end(); ++it)
{ // store element in key_type object
Mymultimap::key_type val = it->first;
System::Console::Write("{0} ", val);
}
System::Console::WriteLine();
return (0);
}
a b c
multimap::lower_bound
Находит начало диапазона, соответствующего указанному ключу.
Синтаксис
iterator lower_bound(key_type key);
Параметры
key
Искомое значение ключа.
Замечания
Функция-член определяет первый элемент X
в управляемой последовательности, которая имеет эквивалентное упорядочивание key
. Если такой элемент не существует, возвращается end()
; в противном случае возвращается итератор, указывающий X
. Он используется для поиска начала последовательности элементов в настоящее время в управляемой последовательности, которая соответствует указанному ключу.
Пример
// cliext_multimap_lower_bound.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
System::Console::WriteLine("lower_bound(L'x')==end() = {0}",
c1.lower_bound(L'x') == c1.end());
Mymultimap::iterator it = c1.lower_bound(L'a');
System::Console::WriteLine("*lower_bound(L'a') = [{0} {1}]",
it->first, it->second);
it = c1.lower_bound(L'b');
System::Console::WriteLine("*lower_bound(L'b') = [{0} {1}]",
it->first, it->second);
return (0);
}
[a 1] [b 2] [c 3]
lower_bound(L'x')==end() = True
*lower_bound(L'a') = [a 1]
*lower_bound(L'b') = [b 2]
multimap::make_value
Создает объект value.
Синтаксис
static value_type make_value(key_type key, mapped_type mapped);
Параметры
key
Значение ключа для использования.
mapped
Сопоставленное значение для поиска.
Замечания
Функция-член возвращает value_type
объект, ключ которого находится key
в сопоставленном значении mapped
. Он используется для создания объекта, подходящего для использования с несколькими другими функциями-членами.
Пример
// cliext_multimap_make_value.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
return (0);
}
[a 1] [b 2] [c 3]
multimap::mapped_type
Тип сопоставленного значения, связанного с каждым ключом.
Синтаксис
typedef Mapped mapped_type;
Замечания
Этот тип является синонимом для параметра шаблона Mapped
.
Пример
// cliext_multimap_mapped_type.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]" using mapped_type
for (Mymultimap::iterator it = c1.begin(); it != c1.end(); ++it)
{ // store element in mapped_type object
Mymultimap::mapped_type val = it->second;
System::Console::Write("{0} ", val);
}
System::Console::WriteLine();
return (0);
}
1 2 3
multimap::multimap
Создает объект контейнера.
Синтаксис
multimap();
explicit multimap(key_compare^ pred);
multimap(multimap<Key, Mapped>% right);
multimap(multimap<Key, Mapped>^ right);
template<typename InIter>
multimapmultimap(InIter first, InIter last);
template<typename InIter>
multimap(InIter first, InIter last,
key_compare^ pred);
multimap(System::Collections::Generic::IEnumerable<GValue>^ right);
multimap(System::Collections::Generic::IEnumerable<GValue>^ right,
key_compare^ pred);
Параметры
first
Начало диапазона для вставки.
last
Конец диапазона для вставки.
pred
Упорядочение предиката для управляемой последовательности.
right
Объект или диапазон для вставки.
Замечания
Конструктор:
multimap();
инициализирует контролируемую последовательность без элементов с предикатом key_compare()
по умолчанию. Он используется для указания пустой управляемой последовательности по умолчанию с предикатом упорядочивания по умолчанию.
Конструктор:
explicit multimap(key_compare^ pred);
инициализирует контролируемую последовательность без элементов с предикатом pred
упорядочения. Он используется для указания пустой управляемой последовательности с указанным предикатом упорядочения.
Конструктор:
multimap(multimap<Key, Mapped>% right);
инициализирует управляемую последовательность с помощью последовательности [right.begin()
, right.end()
с предикатом порядка по умолчанию. Он используется для указания начальной управляемой последовательности, которая является копией последовательности, управляемой multimap
объектом right
, с предикатом порядка по умолчанию.
Конструктор:
multimap(multimap<Key, Mapped>^ right);
инициализирует управляемую последовательность с помощью последовательности [right->begin()
, right->end()
с предикатом порядка по умолчанию. Он используется для указания начальной управляемой последовательности, которая является копией последовательности, управляемой multimap
объектом right
, с предикатом порядка по умолчанию.
Конструктор:
template<typename InIter> multimap(InIter first, InIter last);
инициализирует управляемую последовательность с помощью последовательности [first
, last
с предикатом порядка по умолчанию. Он используется для создания управляемой последовательности копии другой последовательности с предикатом по умолчанию.
Конструктор:
template<typename InIter> multimap(InIter first, InIter last, key_compare^ pred);
инициализирует контролируемую последовательность с помощью последовательности [first
, last
), с предикатом pred
упорядочения. Он используется для создания управляемой последовательности копией другой последовательности с указанным предикатом упорядочения.
Конструктор:
multimap(System::Collections::Generic::IEnumerable<Key>^ right);
инициализирует контролируемую последовательность с последовательностью, указанной перечислителем right
, с предикатом порядка по умолчанию. Он используется для создания управляемой последовательности копии другой последовательности, описанной перечислителем, с предикатом по умолчанию.
Конструктор:
multimap(System::Collections::Generic::IEnumerable<Key>^ right, key_compare^ pred);
инициализирует контролируемую последовательность с последовательностью, назначенной перечислителем right
, с предикатом pred
упорядочения. Он используется для создания управляемой последовательности копии другой последовательности, описанной перечислителем, с указанным предикатом упорядочения.
Пример
// cliext_multimap_construct.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
// construct an empty container
Mymultimap c1;
System::Console::WriteLine("size() = {0}", c1.size());
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// construct with an ordering rule
Mymultimap c2 = cliext::greater_equal<wchar_t>();
System::Console::WriteLine("size() = {0}", c2.size());
c2.insert(c1.begin(), c1.end());
for each (Mymultimap::value_type elem in c2)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// construct with an iterator range
Mymultimap c3(c1.begin(), c1.end());
for each (Mymultimap::value_type elem in c3)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// construct with an iterator range and an ordering rule
Mymultimap c4(c1.begin(), c1.end(),
cliext::greater_equal<wchar_t>());
for each (Mymultimap::value_type elem in c4)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// construct with an enumeration
Mymultimap c5( // NOTE: cast is not needed
(System::Collections::Generic::IEnumerable<
Mymultimap::value_type>^)%c3);
for each (Mymultimap::value_type elem in c5)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// construct with an enumeration and an ordering rule
Mymultimap c6( // NOTE: cast is not needed
(System::Collections::Generic::IEnumerable<
Mymultimap::value_type>^)%c3,
cliext::greater_equal<wchar_t>());
for each (Mymultimap::value_type elem in c6)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// construct by copying another container
Mymultimap c7(c4);
for each (Mymultimap::value_type elem in c7)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// construct by copying a container handle
Mymultimap c8(%c3);
for each (Mymultimap::value_type elem in c8)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
return (0);
}
size() = 0
[a 1] [b 2] [c 3]
size() = 0
[c 3] [b 2] [a 1]
[a 1] [b 2] [c 3]
[c 3] [b 2] [a 1]
[a 1] [b 2] [c 3]
[c 3] [b 2] [a 1]
[c 3] [b 2] [a 1]
[a 1] [b 2] [c 3]
multimap::operator=
Заменяет управляемую последовательность.
Синтаксис
multimap<Key, Mapped>% operator=(multimap<Key, Mapped>% right);
Параметры
right
Контейнер для копирования.
Замечания
Оператор-член копирует right
в объект, а затем возвращает *this
. Он позволяет заменить управляемую последовательность копией управляемой последовательности в right
.
Пример
// cliext_multimap_operator_as.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// assign to a new container
Mymultimap c2;
c2 = c1;
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c2)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
return (0);
}
[a 1] [b 2] [c 3]
[a 1] [b 2] [c 3]
multimap::rbegin
Задает начало обратной управляемой последовательности.
Синтаксис
reverse_iterator rbegin();
Замечания
Функция-член возвращает обратный итератор, указывающий последний элемент управляемой последовательности или только за началом пустой последовательности. Следовательно, он обозначает beginning
обратную последовательность. Он используется для получения итератора, обозначающего current
начало управляемой последовательности, отображаемой в обратном порядке, но его состояние может измениться, если длина управляемой последовательности изменяется.
Пример
// cliext_multimap_rbegin.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// inspect first two items in reversed sequence
Mymultimap::reverse_iterator rit = c1.rbegin();
System::Console::WriteLine("*rbegin() = [{0} {1}]",
rit->first, rit->second);
++rit;
System::Console::WriteLine("*++rbegin() = [{0} {1}]",
rit->first, rit->second);
return (0);
}
[a 1] [b 2] [c 3]
*rbegin() = [c 3]
*++rbegin() = [b 2]
multimap::reference
Тип ссылки на элемент.
Синтаксис
typedef value_type% reference;
Замечания
Тип описывает ссылку на элемент.
Пример
// cliext_multimap_reference.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
Mymultimap::iterator it = c1.begin();
for (; it != c1.end(); ++it)
{ // get a reference to an element
Mymultimap::reference ref = *it;
System::Console::Write("[{0} {1}] ", ref->first, ref->second);
}
System::Console::WriteLine();
return (0);
}
[a 1] [b 2] [c 3]
multimap::rend
Задает конец обратной управляемой последовательности.
Синтаксис
reverse_iterator rend();
Замечания
Функция-член возвращает обратный итератор, указывающий только за начало управляемой последовательности. Следовательно, он обозначает end
обратную последовательность. Он используется для получения итератора, который обозначает current
конец управляемой последовательности, наблюдаемой в обратном порядке, но его состояние может измениться, если длина управляемой последовательности изменяется.
Пример
// cliext_multimap_rend.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// inspect first two items in reversed sequence
Mymultimap::reverse_iterator rit = c1.rend();
--rit;
--rit;
System::Console::WriteLine("*-- --rend() = [{0} {1}]",
rit->first, rit->second);
++rit;
System::Console::WriteLine("*--rend() = [{0} {1}]",
rit->first, rit->second);
return (0);
}
[a 1] [b 2] [c 3]
*-- --rend() = [b 2]
*--rend() = [a 1]
multimap::reverse_iterator
Тип обратного итератора для управляемой последовательности.
Синтаксис
typedef T3 reverse_iterator;
Замечания
Тип описывает объект неопределенного типа T3
, который может служить обратным итератором для управляемой последовательности.
Пример
// cliext_multimap_reverse_iterator.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]" reversed
Mymultimap::reverse_iterator rit = c1.rbegin();
for (; rit != c1.rend(); ++rit)
System::Console::Write("[{0} {1}] ", rit->first, rit->second);
System::Console::WriteLine();
return (0);
}
[c 3] [b 2] [a 1]
multimap::size
Подсчитывает количество элементов.
Синтаксис
size_type size();
Замечания
Функция-член возвращает длину управляемой последовательности. Он используется для определения количества элементов в текущей управляемой последовательности. Если все, что вам нужно, заключается в том, имеет ли последовательность ненулевое значение, см empty()
. раздел .
Пример
// cliext_multimap_size.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// clear the container and reinspect
c1.clear();
System::Console::WriteLine("size() = {0} after clearing", c1.size());
// add elements and clear again
c1.insert(Mymultimap::make_value(L'd', 4));
c1.insert(Mymultimap::make_value(L'e', 5));
System::Console::WriteLine("size() = {0} after adding 2", c1.size());
return (0);
}
[a 1] [b 2] [c 3]
size() = 0 after clearing
size() = 2 after adding 2
multimap::size_type
Тип расстояния со знаком между двумя элементами.
Синтаксис
typedef int size_type;
Замечания
Тип описывает число элементов, не являющихся отрицательными.
Пример
// cliext_multimap_size_type.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// compute positive difference
Mymultimap::size_type diff = 0;
for (Mymultimap::iterator it = c1.begin(); it != c1.end(); ++it)
++diff;
System::Console::WriteLine("end()-begin() = {0}", diff);
return (0);
}
[a 1] [b 2] [c 3]
end()-begin() = 3
multimap::swap
Меняет местами содержимое двух контейнеров.
Синтаксис
void swap(multimap<Key, Mapped>% right);
Параметры
right
Контейнер для обмена содержимым.
Замечания
Функция-член меняет местами управляемые последовательности между this
и right
. Он делает это в постоянном времени, и он не вызывает исключений. Вы используете его в качестве быстрого способа обмена содержимым двух контейнеров.
Пример
// cliext_multimap_swap.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// construct another container with repetition of values
Mymultimap c2;
c2.insert(Mymultimap::make_value(L'd', 4));
c2.insert(Mymultimap::make_value(L'e', 5));
c2.insert(Mymultimap::make_value(L'f', 6));
for each (Mymultimap::value_type elem in c2)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// swap and redisplay
c1.swap(c2);
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
for each (Mymultimap::value_type elem in c2)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
return (0);
}
[a 1] [b 2] [c 3]
[d 4] [e 5] [f 6]
[d 4] [e 5] [f 6]
[a 1] [b 2] [c 3]
multimap::to_array
Копирует контролируемую последовательность в новый массив.
Синтаксис
cli::array<value_type>^ to_array();
Замечания
Функция-член возвращает массив, содержащий контролируемую последовательность. Он используется для получения копии управляемой последовательности в форме массива.
Пример
// cliext_multimap_to_array.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// copy the container and modify it
cli::array<Mymultimap::value_type>^ a1 = c1.to_array();
c1.insert(Mymultimap::make_value(L'd', 4));
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// display the earlier array copy
for each (Mymultimap::value_type elem in a1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
return (0);
}
[a 1] [b 2] [c 3] [d 4]
[a 1] [b 2] [c 3]
multimap::upper_bound
Находит конец диапазона, соответствующий указанному ключу.
Синтаксис
iterator upper_bound(key_type key);
Параметры
key
Искомое значение ключа.
Замечания
Функция-член определяет последний элемент X
в управляемой последовательности, которая имеет эквивалентное упорядочивание key
. Если такой элемент отсутствует или X
является последним элементом в управляемой последовательности, он возвращается end()
; в противном случае возвращается итератор, указывающий первый элемент за пределами X
. Он используется для поиска конца последовательности элементов в настоящее время в управляемой последовательности, которая соответствует указанному ключу.
Пример
// cliext_multimap_upper_bound.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
System::Console::WriteLine("upper_bound(L'x')==end() = {0}",
c1.upper_bound(L'x') == c1.end());
Mymultimap::iterator it = c1.upper_bound(L'a');
System::Console::WriteLine("*upper_bound(L'a') = [{0} {1}]",
it->first, it->second);
it = c1.upper_bound(L'b');
System::Console::WriteLine("*upper_bound(L'b') = [{0} {1}]",
it->first, it->second);
return (0);
}
[a 1] [b 2] [c 3]
upper_bound(L'x')==end() = True
*upper_bound(L'a') = [b 2]
*upper_bound(L'b') = [c 3]
multimap::value_comp
Копирует делегат упорядочивания для двух значений элементов.
Синтаксис
value_compare^ value_comp();
Замечания
Функция-член возвращает делегат упорядочивания, используемый для упорядочивания управляемой последовательности. Он используется для сравнения двух значений элементов.
Пример
// cliext_multimap_value_comp.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::map<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
Mymultimap::value_compare^ kcomp = c1.value_comp();
System::Console::WriteLine("compare([L'a', 1], [L'a', 1]) = {0}",
kcomp(Mymultimap::make_value(L'a', 1),
Mymultimap::make_value(L'a', 1)));
System::Console::WriteLine("compare([L'a', 1], [L'b', 2]) = {0}",
kcomp(Mymultimap::make_value(L'a', 1),
Mymultimap::make_value(L'b', 2)));
System::Console::WriteLine("compare([L'b', 2], [L'a', 1]) = {0}",
kcomp(Mymultimap::make_value(L'b', 2),
Mymultimap::make_value(L'a', 1)));
System::Console::WriteLine();
return (0);
}
compare([L'a', 1], [L'a', 1]) = False
compare([L'a', 1], [L'b', 2]) = True
compare([L'b', 2], [L'a', 1]) = False
multimap::value_compare
Делегат упорядочивания для двух значений элементов.
Синтаксис
Microsoft::VisualC::StlClr::BinaryDelegate<generic_value, generic_value, bool>
value_compare;
Замечания
Тип является синонимом делегата, который определяет порядок его аргументов значений.
Пример
// cliext_multimap_value_compare.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::map<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
Mymultimap::value_compare^ kcomp = c1.value_comp();
System::Console::WriteLine("compare([L'a', 1], [L'a', 1]) = {0}",
kcomp(Mymultimap::make_value(L'a', 1),
Mymultimap::make_value(L'a', 1)));
System::Console::WriteLine("compare([L'a', 1], [L'b', 2]) = {0}",
kcomp(Mymultimap::make_value(L'a', 1),
Mymultimap::make_value(L'b', 2)));
System::Console::WriteLine("compare([L'b', 2], [L'a', 1]) = {0}",
kcomp(Mymultimap::make_value(L'b', 2),
Mymultimap::make_value(L'a', 1)));
System::Console::WriteLine();
return (0);
}
compare([L'a', 1], [L'a', 1]) = False
compare([L'a', 1], [L'b', 2]) = True
compare([L'b', 2], [L'a', 1]) = False
multimap::value_type
Тип элемента.
Синтаксис
typedef generic_value value_type;
Замечания
Тип является синонимом generic_value
.
Пример
// cliext_multimap_value_type.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]" using value_type
for (Mymultimap::iterator it = c1.begin(); it != c1.end(); ++it)
{ // store element in value_type object
Mymultimap::value_type val = *it;
System::Console::Write("[{0} {1}] ", val->first, val->second);
}
System::Console::WriteLine();
return (0);
}
[a 1] [b 2] [c 3]
operator!=
(multimap)
Список не равного сравнения.
Синтаксис
template<typename Key,
typename Mapped>
bool operator!=(multimap<Key, Mapped>% left,
multimap<Key, Mapped>% right);
Параметры
left
Левый контейнер для сравнения.
right
Правый контейнер для сравнения.
Замечания
Функция оператора возвращает .!(left == right)
Вы используете его для проверки того, не упорядочено ли left
одно и то же, что right
и при сравнении двух многомамерных карт по элементу.
Пример
// cliext_multimap_operator_ne.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// assign to a new container
Mymultimap c2;
c2.insert(Mymultimap::make_value(L'a', 1));
c2.insert(Mymultimap::make_value(L'b', 2));
c2.insert(Mymultimap::make_value(L'd', 4));
// display contents " [a 1] [b 2] [d 4]"
for each (Mymultimap::value_type elem in c2)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
System::Console::WriteLine("[a b c] != [a b c] is {0}",
c1 != c1);
System::Console::WriteLine("[a b c] != [a b d] is {0}",
c1 != c2);
return (0);
}
[a 1] [b 2] [c 3]
[a 1] [b 2] [d 4]
[a b c] != [a b c] is False
[a b c] != [a b d] is True
operator<
(multimap)
Список меньше сравнения.
Синтаксис
template<typename Key,
typename Mapped>
bool operator<(multimap<Key, Mapped>% left,
multimap<Key, Mapped>% right);
Параметры
left
Левый контейнер для сравнения.
right
Правый контейнер для сравнения.
Замечания
Функция оператора возвращает значение true, если для наименьшей позиции i
, для которой !(right[i] < left[i])
она также имеет значение true left[i] < right[i]
. В противном случае возвращается значение left->size() < right->size()
. Вы используете его для проверки того, упорядочено ли left
оно до right
того, когда два многофакторных карты сравниваются по элементу.
Пример
// cliext_multimap_operator_lt.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// assign to a new container
Mymultimap c2;
c2.insert(Mymultimap::make_value(L'a', 1));
c2.insert(Mymultimap::make_value(L'b', 2));
c2.insert(Mymultimap::make_value(L'd', 4));
// display contents " [a 1] [b 2] [d 4]"
for each (Mymultimap::value_type elem in c2)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
System::Console::WriteLine("[a b c] < [a b c] is {0}",
c1 < c1);
System::Console::WriteLine("[a b c] < [a b d] is {0}",
c1 < c2);
return (0);
}
[a 1] [b 2] [c 3]
[a 1] [b 2] [d 4]
[a b c] < [a b c] is False
[a b c] < [a b d] is True
operator<=
(multimap)
Список меньше или равного сравнения.
Синтаксис
template<typename Key,
typename Mapped>
bool operator<=(multimap<Key, Mapped>% left,
multimap<Key, Mapped>% right);
Параметры
left
Левый контейнер для сравнения.
right
Правый контейнер для сравнения.
Замечания
Функция оператора возвращает .!(right < left)
Вы используете его для проверки того, не упорядочено right
ли left
после сравнения двух многофакторных карт по элементу.
Пример
// cliext_multimap_operator_le.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// assign to a new container
Mymultimap c2;
c2.insert(Mymultimap::make_value(L'a', 1));
c2.insert(Mymultimap::make_value(L'b', 2));
c2.insert(Mymultimap::make_value(L'd', 4));
// display contents " [a 1] [b 2] [d 4]"
for each (Mymultimap::value_type elem in c2)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
System::Console::WriteLine("[a b c] <= [a b c] is {0}",
c1 <= c1);
System::Console::WriteLine("[a b d] <= [a b c] is {0}",
c2 <= c1);
return (0);
}
[a 1] [b 2] [c 3]
[a 1] [b 2] [d 4]
[a b c] <= [a b c] is True
[a b d] <= [a b c] is False
operator==
(multimap)
Список равных сравнений.
Синтаксис
template<typename Key,
typename Mapped>
bool operator==(multimap<Key, Mapped>% left,
multimap<Key, Mapped>% right);
Параметры
left
Левый контейнер для сравнения.
right
Правый контейнер для сравнения.
Замечания
Функция оператора возвращает значение true, только если последовательности, left
контролируемые и имеют одинаковую длину и right
для каждой позицииi
. left[i] == right[i]
Вы используете его для проверки того, упорядочено ли left
одно и то же, что right
и при сравнении двух многофакторных карт по элементу.
Пример
// cliext_multimap_operator_eq.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// assign to a new container
Mymultimap c2;
c2.insert(Mymultimap::make_value(L'a', 1));
c2.insert(Mymultimap::make_value(L'b', 2));
c2.insert(Mymultimap::make_value(L'd', 4));
// display contents " [a 1] [b 2] [d 4]"
for each (Mymultimap::value_type elem in c2)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
System::Console::WriteLine("[a b c] == [a b c] is {0}",
c1 == c1);
System::Console::WriteLine("[a b c] == [a b d] is {0}",
c1 == c2);
return (0);
}
[a 1] [b 2] [c 3]
[a 1] [b 2] [d 4]
[a b c] == [a b c] is True
[a b c] == [a b d] is False
operator>
(multimap)
Список больше, чем сравнение.
Синтаксис
template<typename Key,
typename Mapped>
bool operator>(multimap<Key, Mapped>% left,
multimap<Key, Mapped>% right);
Параметры
left
Левый контейнер для сравнения.
right
Правый контейнер для сравнения.
Замечания
Функция оператора возвращает .right < left
Вы используете его для проверки того, упорядочивается right
ли left
после сравнения двух многозначных карт по элементу.
Пример
// cliext_multimap_operator_gt.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// assign to a new container
Mymultimap c2;
c2.insert(Mymultimap::make_value(L'a', 1));
c2.insert(Mymultimap::make_value(L'b', 2));
c2.insert(Mymultimap::make_value(L'd', 4));
// display contents " [a 1] [b 2] [d 4]"
for each (Mymultimap::value_type elem in c2)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
System::Console::WriteLine("[a b c] > [a b c] is {0}",
c1 > c1);
System::Console::WriteLine("[a b d] > [a b c] is {0}",
c2 > c1);
return (0);
}
[a 1] [b 2] [c 3]
[a 1] [b 2] [d 4]
[a b c] > [a b c] is False
[a b d] > [a b c] is True
operator>=
(multimap)
Список больше или равного сравнения.
Синтаксис
template<typename Key,
typename Mapped>
bool operator>=(multimap<Key, Mapped>% left,
multimap<Key, Mapped>% right);
Параметры
left
Левый контейнер для сравнения.
right
Правый контейнер для сравнения.
Замечания
Функция оператора возвращает .!(left < right)
Вы используете его для проверки того, не упорядочено right
ли left
два многофакторных карты по элементу.
Пример
// cliext_multimap_operator_ge.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::multimap<wchar_t, int> Mymultimap;
int main()
{
Mymultimap c1;
c1.insert(Mymultimap::make_value(L'a', 1));
c1.insert(Mymultimap::make_value(L'b', 2));
c1.insert(Mymultimap::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (Mymultimap::value_type elem in c1)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
// assign to a new container
Mymultimap c2;
c2.insert(Mymultimap::make_value(L'a', 1));
c2.insert(Mymultimap::make_value(L'b', 2));
c2.insert(Mymultimap::make_value(L'd', 4));
// display contents " [a 1] [b 2] [d 4]"
for each (Mymultimap::value_type elem in c2)
System::Console::Write("[{0} {1}] ", elem->first, elem->second);
System::Console::WriteLine();
System::Console::WriteLine("[a b c] >= [a b c] is {0}",
c1 >= c1);
System::Console::WriteLine("[a b c] >= [a b d] is {0}",
c1 >= c2);
return (0);
}
[a 1] [b 2] [c 3]
[a 1] [b 2] [d 4]
[a b c] >= [a b c] is True
[a b c] >= [a b d] is False