C++ set 调用一次erase删除多个元素
时间: 2023-10-06 18:08:24 浏览: 86
在 C++ STL 中,set 的 erase 函数可以接受一个迭代器范围,从而一次性删除多个元素。具体使用方法如下:
```cpp
#include <set>
int main() {
std::set<int> mySet = {1, 2, 3, 4, 5};
// 删除元素值在 [2, 4) 范围内的所有元素
mySet.erase(mySet.lower_bound(2), mySet.upper_bound(4));
return 0;
}
```
在上述代码中,使用 lower_bound 和 upper_bound 函数获取了两个迭代器,这两个迭代器分别指向了值为 2 和 4 的元素位置。将这两个迭代器作为参数传递给 erase 函数,就可以删除这个范围内的所有元素。
注意,erase 函数删除元素后,被删除元素的迭代器都会失效,因此在使用迭代器时需要格外小心。
相关问题
unordered_map中删除一个元素
要从unordered_map中删除一个元素,可以使用erase()函数。有三种使用方法:
1. 通过位置索引:使用迭代器指向要删除的元素,并调用erase()函数。语法为:iterator erase(const_iterator position)。
2. 通过键值查找:使用要删除的元素的键值作为参数,并调用erase()函数。语法为:size_type erase(const key_type& k)。
3. 通过范围指定:使用范围的迭代器作为参数,并调用erase()函数。范围包括第一个迭代器指向的元素,但不包括最后一个迭代器指向的元素。语法为:iterator erase(const_iterator first, const_iterator last)。
请注意,unordered_map容器的删除操作可能会导致元素存储的顺序被打乱,因为它不保持元素的特定顺序。
以下是一个示例代码,展示如何使用erase()函数从unordered_map中删除一个元素:
```cpp
#include <iostream>
#include <unordered_map>
#include <string>
int main() {
std::unordered_map<std::string, double> mymap = {
{"apple", 1.50},
{"banana", 0.75},
{"orange", 0.90}
};
// 删除指定键值的元素
mymap.erase("banana");
// 删除通过迭代器指定的元素
auto it = mymap.find("orange");
if (it != mymap.end()) {
mymap.erase(it);
}
// 输出剩余元素数量
std::cout << "剩余元素数量: " << mymap.size() << std::endl;
return 0;
}
```
输出结果为:
```
剩余元素数量: 1
```
这段代码演示了如何使用erase()函数从unordered_map中删除一个元素。首先,使用键值"banana"调用erase()函数删除该元素。然后,使用迭代器指向"orange"的元素,并调用erase()函数删除该元素。最后,输出剩余元素数量为1,显示成功删除了一个元素。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* [12 STL【unordered_map介绍】【unordered_map获取/添加/删除元素 成员函数】【unordered_multimap】...](https://blog.csdn.net/weixin_44484715/article/details/116083724)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"]
- *2* *3* [C++ unordered_map 和 unordered_set 常用函数](https://blog.csdn.net/qq_40876059/article/details/123699886)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"]
[ .reference_list ]
c++ set map
引用中的代码展示了如何使用set容器,其中set是一个有序且唯一的容器。在引用中,首先定义了一个set容器s并初始化了一些元素,然后使用迭代器pos查找并删除了值为20的元素,最后使用for循环遍历并输出set容器中的所有元素。
引用中的代码展示了使用set容器的更多操作。在引用中,首先定义了一个set容器s并初始化了一些元素,然后使用erase函数尝试删除一个不存在的元素30,接着使用迭代器pos查找并删除了值为20的元素,最后再次使用for循环遍历并输出set容器中的所有元素。
引用中的代码也展示了如何使用set容器。在引用中,定义了一个test_set1函数,其中初始化了一些元素并将它们插入到set容器s中,然后使用for循环遍历并输出set容器中的所有元素。在main函数中调用了test_set1函数。
综上所述,c++中的set是一个有序且唯一的容器,其中的元素以升序排列,并且不允许重复。set容器提供了插入、删除、查找等操作,并且遍历时按照元素升序的顺序输出。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *2* *3* [【C++】set和map](https://blog.csdn.net/m0_62179366/article/details/127715195)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"]
[ .reference_list ]