C++
容器 | Containers

std::vector::erase

STD::向量::擦除

(1)
iterator erase( iterator pos (until C++11)
iterator erase( const_iterator pos (since C++11)
(2)
iterator erase( iterator first, iterator last (until C++11)
iterator erase( const_iterator first, const_iterator last (since C++11)

从容器中移除指定的元素。

1%29移除pos...

2%29移除范围内的元素。[first; last)...

在擦除点或之后使迭代器和引用无效,包括end()迭代器。

迭代器pos必须是有效的和可撤销的。因此end()迭代器%28有效,但不可取消引用%29不能用作pos...

迭代器first如果first==last:擦除空范围是不操作的。

参数

pos-iterator to the element to remove
first, last-range of elements to remove

类型要求

-T必须符合可移动分配的要求。

返回值

最后删除元素之后的Iterator。如果迭代器pos引用最后一个元素,end()返回迭代器。

例外

的赋值运算符引发异常时,才会引发T...

复杂性

线性:对T的析构函数的调用数与擦除的元素数相同,T的赋值运算符称为向量中删除元素之后的元素数的次数。

二次

#include <vector> #include <iostream> int main( ) { std::vector<int> c{0, 1, 2, 3, 4, 5, 6, 7, 8, 9}; for (auto &i : c) { std::cout << i << " "; } std::cout << '\n'; c.erase(c.begin() for (auto &i : c) { std::cout << i << " "; } std::cout << '\n'; c.erase(c.begin()+2, c.begin()+5 for (auto &i : c) { std::cout << i << " "; } std::cout << '\n'; }

二次

产出:

二次

0 1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9 1 2 6 7 8 9

二次

另见

clearclears the contents (public member function)

© cppreference.com

在CreativeCommonsAttribution下授权-ShareAlike未移植许可v3.0。