C++ STL 中的 multimap::erase()
在本文中,我们将讨论 C++ STL 中 multimap::erase() 函数的工作原理、语法和示例。
什么是 C++ STL 中的 Multimap?
Multimap 是关联容器,类似于 map 容器。它还方便以特定顺序存储由键值和映射值组合而成的元素。在 multimap 容器中,可以有多个元素与同一个键关联。数据在内部始终借助其关联的键进行排序。
什么是 multimap::erase()?
multimap::erase() 函数是 C++ STL 中的内置函数,它在 <map> 头文件中定义。erase() 用于从 multimap 容器中删除或擦除元素。
此函数可以通过其键、位置或给定范围来删除或擦除元素。当我们运行此函数时,multimap 容器的大小将减少正在删除的元素的数量。
语法
multimap_name.erase(key_type key); multimap_name.erase(const_iterator it); multimap_name.erase(const_ iterator start, const_itertaor end);
参数
该函数接受以下参数:
key - 这是我们希望删除其元素的键的位置。
it - 我们希望从其位置开始删除元素的迭代器位置。
start, end - 这定义了应从哪个位置到哪个位置删除元素集的范围。
返回值
此函数返回从关联容器中删除的元素数量。
输入
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; //declaring iterator to traverse the elements multimap<int,char>:: iterator i; //inserting elements to 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); //elements of 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; //declaring iterator to traverse the elements multimap<int,char>:: iterator i; //inserting elements to 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')); //elements in multimap before erasing 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); //elements of 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; //declaring iterator to traverse the elements multimap<int,char>:: iterator i; //inserting elements to 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')); //elements in multimap before erasing 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); //elements of 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
广告