使用迭代器从C++中的向量末尾移除元素
Removing elements from the end of a vector in C++ using iterator
我想从最后一个元素开始,以相反的顺序从向量中删除元素。据我所知,使用迭代器最简单的方法是:
std::vector<int> data = ...
std::vector<int>::iterator iter;
for(iter = data.end() - 1; iter != data.begin() - 1; iter--) {
data.erase(iter);
}
我的问题是,这些erase()调用中的每一个都是O(1)吗?因为我们在最后删除,尽管删除的一般复杂性是O(n)?此外,假设向量至少有一个元素,这个代码"安全"吗?
不,您的算法有UB。如果没有,它就会有O(n)
将正文更改为此将删除UB:iter = data.erase(iter);
为什么?因为vector.erase()
的行为如下:
- 效果:在擦除点或擦除点之后使迭代器和引用无效
- 复杂性:T的析构函数被称为等于元素数量的次数删除,但T的移动赋值运算符被称为等于在被擦除的元素之后的向量中的元素
如果像这样重写循环,它甚至可以用于空容器:
for(auto it = data.end(); it!=data.begin(); it = data.erase(it-1)) /**/;
它等于:
std::remove_if(data.rbegin(), data.rend(), [](data::reference x){return true;});
无论如何,使用data.clear()
、data.resize(0)
或用临时空向量交换很可能会更快。
除非您真的需要以相反的顺序删除它们,否则最好只调用data.clear()
。
否则,不,这是不"安全"的:形成data.begin() - 1
是未定义的,在调用.erase
后递减iter
也是未定义的。重复数据删除程序对此进行了很好的修复。
Kinda。std::vector erase()的复杂性是
删除(破坏)的元素数量加上上次删除(移动)的元素之后的元素数量为线性。
基于此来源:http://www.cplusplus.com/reference/vector/vector/erase/
当你只移除一个元素和它的最后一个元素时,它与N=1是线性的,可以解释为O(1)常数。
相关文章:
- 向量元素的引用地址与它所指向的向量元素的地址不同.为什么
- C++:如何循环通过向量中的整数元素
- 如何在C++向量中奇数元素前面加上值-1,我在使用insert函数时遇到了问题
- 不允许在向量中添加更多元素
- 基于范围的 for 循环:迭代使用一个元素扩展的向量
- 使用并行参数向量调用元素向量的成员函数
- C++ 查找字符串中存在的元素向量
- 包含 std::threads 的元素向量
- 避免从单一元素向量转换为基元类型
- 对自定义元素向量进行排序时出现意外(至少对我来说)行为
- 如何为对元素(向量和int)配对创建unique_ptr也是unique_ptr
- 元素向量乘法 C++(代码不起作用)
- 时间和空间复杂性在二叉树的每个级别创建元素向量(NON-BST)
- 遍历结构元素向量
- 犰狳C++中的元素向量或矩阵乘法
- 为什么'std::vector<int> b{2};'创建 1 元素向量,而不是 2 元素向量?
- 可移动元素向量的大小调整是否有效?
- 唯一元素向量的c++模板函数
- 获取索引和元素-向量问题
- 定义一个生成元素向量的函数时,正确的方法是什么?