std::unordered_map删除
时间: 2024-03-18 21:37:43 浏览: 17
std::unordered_map是C++标准库中的一个关联容器,它提供了一种键值对的映射关系。要删除std::unordered_map中的元素,可以使用erase()函数。
erase()函数有多种用法,可以根据键或者迭代器来删除元素。如果知道要删除的键,可以直接使用键作为参数调用erase()函数。例如,要删除键为key的元素,可以使用以下代码:
```cpp
std::unordered_map<KeyType, ValueType> myMap;
// ...
myMap.erase(key);
```
如果要删除多个元素,可以使用迭代器进行循环删除。例如,要删除所有满足某个条件的元素,可以使用以下代码:
```cpp
std::unordered_map<KeyType, ValueType> myMap;
// ...
for (auto it = myMap.begin(); it != myMap.end(); ) {
if (someCondition) {
it = myMap.erase(it);
} else {
++it;
}
}
```
在上述代码中,erase()函数返回一个指向下一个元素的迭代器,因此需要将it赋值为erase()的返回值。
相关问题
std::unordered_map插入
std::unordered_map是C++标准库中的一个关联容器,它提供了一种键值对的映射关系。插入操作是向unordered_map中添加新的键值对。
要向std::unordered_map中插入元素,可以使用insert()函数或者[]操作符。下面是两种插入元素的方式:
1. 使用insert()函数:
```cpp
std::unordered_map<KeyType, ValueType> myMap;
myMap.insert(std::make_pair(key, value));
```
这里的KeyType是键的类型,ValueType是值的类型。通过std::make_pair()函数创建一个键值对,然后使用insert()函数将其插入到unordered_map中。
2. 使用[]操作符:
```cpp
std::unordered_map<KeyType, ValueType> myMap;
myMap[key] = value;
```
这种方式更简洁,直接使用[]操作符将键和值赋给unordered_map。
需要注意的是,如果插入的键已经存在于unordered_map中,那么插入操作将不会生效,即不会覆盖原有的值。
std::unordered_map
std::unordered_map是C++标准库中的一个关联容器,它可以存储一组键值对,并且支持快速的查找、插入和删除操作。
以下是一个使用std::unordered_map的示例代码:
```cpp
#include <unordered_map>
#include <iostream>
int main() {
std::unordered_map<int, std::string> umap;
// 插入键值对
umap.insert(std::make_pair(1, "apple"));
umap.insert(std::make_pair(2, "banana"));
umap.insert(std::make_pair(3, "orange"));
// 查找键值对
int key = 2;
auto it = umap.find(key);
if (it != umap.end()) {
std::cout << "Key " << key << " found, value is " << it->second << std::endl;
} else {
std::cout << "Key " << key << " not found" << std::endl;
}
// 删除键值对
umap.erase(3);
// 遍历键值对
for (const auto& pair : umap) {
std::cout << "Key: " << pair.first << ", Value: " << pair.second << std::endl;
}
return 0;
}
```
这段代码创建了一个std::unordered_map对象umap,插入了三个键值对,然后通过find函数查找指定的键值对,最后删除了一个键值对,并遍历输出了所有的键值对。