map::erase (STL/CLR)
Удаляет элементы в указанных положениях.
iterator erase(iterator where);
iterator erase(iterator first, iterator last);
bool erase(key_type key)
Параметры
first
Начало диапазона для удаления.key
Значение ключа для удаления.last
Элемент диапазона для удаления., где
Элемент для удаления.
Заметки
Функция-член удаляет первый элемент управляемой последовательности, положение where и возвращает итератор, задающий первый элемент оставшиеся за удаленным элементом или map::end (STL/CLR)(), если такой элемент не существует.Используется для удаления одного элемента.
Второй функцию-член удаляет элементы управляемой последовательности в диапазоне [first,last) и возвращает итератор, задающий первый элемент оставшиеся за всеми удаленными элементами или end(), если такой элемент не существует.Используется для удаления ноль или более последовательных элементов.
Третий функцию-член удаляет любой элемент управляемой последовательности клавиша которой имеет ключом key и возвращает количество удаленных элементов.Используется для удаления и посчитать все элементы, которые соответствуют заданному ключу.
Каждое стирание элемента принимает время пропорциональное к логарифму числа элементов в управляемой последовательности.
Пример
// cliext_map_erase.cpp
// compile with: /clr
#include <cliext/map>
typedef cliext::map<wchar_t, int> Mymap;
int main()
{
cliext::map<wchar_t, int> c1;
c1.insert(cliext::map<wchar_t, int>::make_value(L'a', 1));
c1.insert(cliext::map<wchar_t, int>::make_value(L'b', 2));
c1.insert(cliext::map<wchar_t, int>::make_value(L'c', 3));
// display contents " [a 1] [b 2] [c 3]"
for each (cliext::map<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::map<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::map<wchar_t, int>::make_value(L'd', 4));
c1.insert(cliext::map<wchar_t, int>::make_value(L'e', 5));
for each (cliext::map<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);
}
Требования
заголовок: <cliext и сопоставление>
Cliext пространство имен: