C ++ STL中的multimap :: erase()

在本文中,我们将讨论C ++ STL中multimap::erase()函数的工作,语法和示例。

什么是C ++ STL中的Multimap?

多图是关联容器,类似于图容器。它还有助于按特定顺序存储由键值和映射值的组合形成的元素。在多图容器中,可以有多个与同一键关联的元素。始终在内部借助关联的键对数据进行排序。

什么是multimap::erase()?

multimap::erase()函数是C ++ STL中的内置函数,在<map>头文件中定义。erase()用于从多图容器中删除或擦除元素。

此功能可以通过其键,位置或给定范围删除或擦除元素。当我们运行此函数时,多图容器的大小会因要删除的元素数而减少。

语法

multimap_name.erase(key_type key);
multimap_name.erase(const_iterator it);
multimap_name.erase(const_ iterator start, const_itertaor end);

参数

该函数接受以下参数-

  • key-这是我们希望删除其元素的键的位置。

  • -我们希望从中删除元素的迭代器位置。

  • 开始,结束-这定义了从哪个位置到应删除该组元素的位置的范围。

返回值

此函数返回从关联的容器中删除的元素数。

输入值 

std::multimap<int> mymap;
mymap.insert({‘a’, 10});
mymap.insert({‘b’, 20});
mymap.insert({‘c’, 30});
mymap.erase(‘b’);

输出结果 

a:10 c:30

示例

//擦除给定的键

#include<iostream>
#include<map>
using namespace std;
int main(){
   multimap<int,char > mul_1;
   //声明迭代器遍历元素
   multimap<int,char>:: iterator i;
   //将元素插入到multimap1-
   mul_1.insert(make_pair(0,'a'));
   mul_1.insert(make_pair(1,'b'));
   mul_1.insert(make_pair(2,'c'));
   mul_1.insert(make_pair(3,'d'));
   mul_1.insert(make_pair(4,'e'));
   mul_1.insert(make_pair(5,'f'));
   mul_1.insert(make_pair(6,'g'));
   //calling erase() to delete the element
   mul_1.erase(1);
   mul_1.erase(4);
   mul_1.erase(6);
   mul_1.erase(5);
   //multimap1的元素
   cout<<"Elements in multimap1 are: "<<"\n";
   for( i = mul_1.begin(); i!= mul_1.end(); i++){
      cout<<(*i).first<<" "<< (*i).second << "\n";
   }
}

输出结果

如果我们运行上面的代码,它将生成以下输出-

Elements in multimap1 are:
0 a
2 c
3 d

示例

//删除给定范围内的元素

#include<iostream>
#include<map>
using namespace std;
int main(){
   multimap<int,char > mul_1;
   //声明迭代器遍历元素
   multimap<int,char>:: iterator i;
   //将元素插入到multimap1-
   mul_1.insert(make_pair(0,'a'));
   mul_1.insert(make_pair(1,'b'));
   mul_1.insert(make_pair(2,'c'));
   mul_1.insert(make_pair(3,'d'));
   mul_1.insert(make_pair(4,'e'));
   mul_1.insert(make_pair(5,'f'));
   mul_1.insert(make_pair(6,'g'));
   //删除前多图中的元素
   cout<<"Elements in multimap1 are: "<<"\n";
   for( i = mul_1.begin(); i!= mul_1.end(); i++){
      cout<<(*i).first<<" "<< (*i).second << "\n";
   }
   //calling erase() to delete the element
   auto start = mul_1.find(3);
   auto end = mul_1.find(6);
   mul_1.erase(start, end);
   //multimap1的元素 after erasing
   cout<<"Elements in multimap1 are: "<<"\n";
   for( i = mul_1.begin(); i!= mul_1.end(); i++){
      cout<<(*i).first<<" "<< (*i).second << "\n";
   }
}

输出结果

如果我们运行上面的代码,它将生成以下输出-

Elements in multimap1 are:
0 a
1 b
2 c
3 d
4 e
5 f
6 g
Elements in multimap1 are:
0 a
1 b
2 c
6 g

示例

//在给定位置擦除元素

#include<iostream>
#include<map>
using namespace std;
int main(){
   multimap<int,char > mul_1;
   //声明迭代器遍历元素
   multimap<int,char>:: iterator i;
   //将元素插入到multimap1-
   mul_1.insert(make_pair(0,'a'));
   mul_1.insert(make_pair(1,'b'));
   mul_1.insert(make_pair(2,'c'));
   mul_1.insert(make_pair(3,'d'));
   mul_1.insert(make_pair(4,'e'));
   mul_1.insert(make_pair(5,'f'));
   mul_1.insert(make_pair(6,'g'));
   //删除前多图中的元素
   cout<<"Elements in multimap1 are: "<<"\n";
   for( i = mul_1.begin(); i!= mul_1.end(); i++){
      cout<<(*i).first<<" "<< (*i).second << "\n";
   }
   //calling erase() to delete the element
   auto first = mul_1.find(1);
   mul_1.erase(first);
   auto second = mul_1.find(6);
   mul_1.erase(second);
   auto third = mul_1.find(2);
   mul_1.erase(third);
   //multimap1的元素 after erasing
   cout<<"Elements in multimap1 are: "<<"\n";
   for( i = mul_1.begin(); i!= mul_1.end(); i++){
      cout<<(*i).first<<" "<< (*i).second << "\n";
   }
}

输出结果

如果我们运行上面的代码,它将生成以下输出-

Elements in multimap1 are:
0 a
1 b
2 c
3 d
4 e
5 f
6 g
Elements in multimap1 are:
0 a
3 d
4 e
5 f