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
二次
另见
clear | clears the contents (public member function) |
---|
© cppreference.com
在CreativeCommonsAttribution下授权-ShareAlike未移植许可v3.0。