c++中vector erase用法
时间: 2024-08-12 14:01:58 浏览: 69
在 C++ 中,`std::vector` 提供了 `erase` 函数用于删除指定位置的元素。这个函数有两个版本:
1. `erase(iterator)`:接受一个迭代器作为参数,指向要删除的第一个元素。它会返回一个新的迭代器,表示删除元素后的下一个元素的位置。
```cpp
std::vector<int> v = {1, 2, 3, 4, 5};
auto it = v.erase(v.begin() + 2); // 删除第三个元素(索引从0开始)
```
在这个例子中,`it` 现在指向了被删除元素之后的新元素,即 `4`。
2. `erase(first, last)`:接受两个迭代器作为参数,分别指向要删除范围的起始元素和终止元素(但不包括终止元素)。它会删除指定范围内的所有元素,并返回新的结束迭代器。
```cpp
std::vector<int> v = {1, 2, 3, 4, 5};
v.erase(v.begin() + 1, v.begin() + 4); // 删除第2到第4个元素(即2, 3, 4)
```
这将删除 `[2, 3, 4)` 这个区间的所有元素。
注意,`erase` 要求提供合法的迭代器,如果尝试删除超出范围的元素,或者直接传入已失效的迭代器,可能会导致未定义的行为。另外,`erase` 后的剩余元素会被移动到空出的空间,这可能会影响向量的内存布局。
相关问题
c++ vector erase用法大全
C++中的vector容器提供了erase()方法来删除元素。下面是一些c++ vector erase用法的示例:
1. 删除指定位置的元素[^1]:
```cpp
std::vector<int> vec = {1, 2, 3, 4, 5};
vec.erase(vec.begin() + 2); // 删除索引为2的元素
```
2. 删除指定范围的元素:
```cpp
std::vector<int> vec = {1, 2, 3, 4, 5};
vec.erase(vec.begin() + 1, vec.begin() + 4); // 删除索引为1到3的元素
```
3. 删除满足条件的元素[^2]:
```cpp
std::vector<int> vec = {1, 2, 3, 4, 5};
vec.erase(std::remove(vec.begin(), vec.end(), 3), vec.end()); // 删除所有值为3的元素
```
4. 删除满足条件的元素并返回删除的元素个数:
```cpp
std::vector<int> vec = {1, 2, 3, 4, 5};
int count = std::count(vec.begin(), vec.end(), 3);
vec.erase(std::remove(vec.begin(), vec.end(), 3), vec.end()); // 删除所有值为3的元素
```
这些是一些常见的c++ vector erase用法。你可以根据具体的需求选择适合的方法来删除vector中的元素。
c++ vector erase
在 C++ 中,vector 是一个动态数组容器,可以使用 erase() 函数来删除其中的元素。erase() 函数有两种用法:
1. 删除单个元素:
```cpp
vector<int> nums = {1, 2, 3, 4, 5};
vector<int>::iterator it = nums.begin() + 2; // 指向要删除的元素的迭代器
nums.erase(it); // 删除索引位置为2的元素(即值为3的元素)
```
2. 删除一定范围的元素:
```cpp
vector<int> nums = {1, 2, 3, 4, 5};
vector<int>::iterator start = nums.begin() + 1; // 起始位置的迭代器
vector<int>::iterator end = nums.begin() + 3; // 结束位置的迭代器(不包含该位置的元素)
nums.erase(start, end); // 删除索引位置1到2的元素(即值为2和3的元素)
```
注意:在使用 erase() 函数后,原 vector 容器中的元素会被修改,后面的元素会向前移动来填补被删除的空位。
阅读全文