std::vector 如何移除元素
时间: 2024-05-10 07:12:47 浏览: 23
std::vector 是C++ STL中的一个非常常用的容器,它可以动态地增加或减少元素。在移除元素方面,std::vector 提供了多种方法,其中比较常用的是使用 erase() 函数。erase() 函数可以接受一个迭代器作为参数,该迭代器指向要删除元素的位置。以下是示例代码:
```
std::vector<int> vec = {1, 2, 3, 4, 5};
auto it = vec.begin() + 2;
vec.erase(it); // 移除第3个元素(值为3)
```
上述代码中,首先创建一个包含整数元素的 std::vector 对象,并初始化为 {1, 2, 3, 4, 5}。然后使用迭代器访问第3个元素(即值为3的元素),并将该迭代器传递给 erase() 函数。这样就会删除该元素。最终的结果是 vec 变为 {1, 2, 4, 5}。
需要注意的是,erase() 函数会返回一个新的迭代器,该迭代器指向被删除元素的下一个元素。因此,在使用 erase() 函数时,需要谨慎处理迭代器的位置,以避免出现迭代器失效的情况。
相关问题
std::vector 移除多个元素
可以使用 `std::remove_if` 和 `std::vector::erase` 来移除多个元素。
例如,如果我们有一个 `std::vector<int>`,想要移除所有小于 5 的元素,可以这样做:
```cpp
std::vector<int> vec = {1, 6, 2, 7, 3, 8, 4, 9, 5};
vec.erase(std::remove_if(vec.begin(), vec.end(), [](int i){ return i < 5; }), vec.end());
```
`std::remove_if` 会将满足条件的元素移到 vector 的末尾,并返回一个指向第一个被移动的元素的迭代器。然后,我们可以在 `std::vector::erase` 中使用这个迭代器和 vector 的 `end` 迭代器来移除这些元素。
在std::vector<std::vector<int>>删除某些std::vector<int>
在std::vector<std::vector<int>>中删除某些std::vector<int>可以使用erase-remove idiom的方法。这个方法结合了erase和remove两个函数,可以高效地删除指定的元素。
以下是删除某些std::vector<int>的步骤:
1. 使用std::remove_if函数结合lambda表达式来标记要删除的std::vector<int>。lambda表达式可以根据特定的条件来判断是否需要删除。
2. 使用std::erase函数将被标记为删除的std::vector<int>从std::vector<std::vector<int>>中移除。
下面是示例代码:
```cpp
#include <iostream>
#include <vector>
#include <algorithm>
int main() {
std::vector<std::vector<int>> vecOfVec = {{1, 2, 3}, {4, 5, 6}, {7, 8, 9}, {10, 11, 12}};
// 删除满足条件的std::vector<int>
vecOfVec.erase(std::remove_if(vecOfVec.begin(), vecOfVec.end(), [](const std::vector<int>& vec) {
// 根据特定条件判断是否需要删除
return vec.size() == 3; // 删除长度为3的std::vector<int>
}), vecOfVec.end());
// 输出结果
for (const auto& vec : vecOfVec) {
for (const auto& num : vec) {
std::cout << num << " ";
}
std::cout << std::endl;
}
return 0;
}
```
输出结果:
```
4 5 6
7 8 9
```