C++ map删除某个元素
时间: 2023-07-01 10:18:15 浏览: 147
vector, list, map在遍历时删除符合条件的元素实现方法
在 C++ 中,可以使用 erase() 成员函数删除 std::map 中的元素。erase() 函数有多种重载形式,可以删除指定键或指定位置的元素,也可以删除指定范围内的元素。
1. 删除指定键的元素
可以使用 erase() 函数删除指定键的元素,其语法如下:
```c++
size_type erase(const key_type& key);
```
其中,key_type 表示键的类型,size_type 表示返回值的类型,表示删除的元素个数。如果 map 中存在键为 key 的元素,则该元素会被删除,并返回 1;否则不进行操作,返回 0。
下面是一个使用 erase() 函数删除指定键的元素的示例:
```c++
#include <iostream>
#include <map>
int main() {
std::map<std::string, int> my_map = {{"one", 1}, {"two", 2}, {"three", 3}};
// 删除键为 "two" 的元素
my_map.erase("two");
// 遍历输出所有元素
for (auto& x : my_map) {
std::cout << x.first << ": " << x.second << std::endl;
}
return 0;
}
```
2. 删除指定位置的元素
可以使用 erase() 函数删除指定位置的元素,其语法如下:
```c++
iterator erase(const_iterator position);
```
其中,position 表示指向要删除元素的迭代器。该函数会删除 position 指向的元素,并返回指向后一个元素的迭代器。
下面是一个使用 erase() 函数删除指定位置的元素的示例:
```c++
#include <iostream>
#include <map>
int main() {
std::map<std::string, int> my_map = {{"one", 1}, {"two", 2}, {"three", 3}};
// 删除第二个元素
auto it = my_map.begin();
std::advance(it, 1);
my_map.erase(it);
// 遍历输出所有元素
for (auto& x : my_map) {
std::cout << x.first << ": " << x.second << std::endl;
}
return 0;
}
```
3. 删除指定范围的元素
可以使用 erase() 函数删除指定范围的元素,其语法如下:
```c++
iterator erase(const_iterator first, const_iterator last);
```
其中,first 和 last 分别表示要删除的范围的起始位置和终止位置,函数会删除从 first 到 last-1 的所有元素,并返回指向 last 的迭代器。
下面是一个使用 erase() 函数删除指定范围的元素的示例:
```c++
#include <iostream>
#include <map>
int main() {
std::map<std::string, int> my_map = {{"one", 1}, {"two", 2}, {"three", 3}, {"four", 4}};
// 删除第二个和第三个元素
auto first = my_map.begin();
std::advance(first, 1);
auto last = my_map.begin();
std::advance(last, 3);
my_map.erase(first, last);
// 遍历输出所有元素
for (auto& x : my_map) {
std::cout << x.first << ": " << x.second << std::endl;
}
return 0;
}
```
阅读全文