在循环访问嵌套向量时删除元素
Deleting element while iterating through nested vectors
我想知道如何在保留迭代器的同时擦除向量的元素?在这里,我正在循环访问 int 类型的向量:
vector< vector<int> >::iterator row;
vector<int>::iterator col;
for (row = vvi.begin(); row != vvi.end(); row++) {
for (col = row->begin(); col != row->end(); col++) {
if(*col==55)
{
// col=row.erase(col); ?
}
}
}
在您的代码中,如果有多个元素等于 55,则会多次擦除矢量元素,这将花费大量开销来移动元素。更好的解决方案是按照擦除-删除习惯用法将所有限定元素移动到矢量的末尾,然后一次将它们一起擦除。例如:
vector< vector<int> >::iterator row;
vector<int>::iterator col;
for (row = vvi.begin(); row != vvi.end(); row++) {
row->erase( std::remove( row->begin(), row->end(), 55), row->end());
}
std::remove 会将所有等于 55 的元素移动到向量的末尾,并返回它们头部的迭代器。row->erase(iterator1, iterator2( 将擦除 2 个迭代器之间的所有元素。
而且您不再需要关心迭代器。
相关文章:
- 如何从存储在std::映射中的std::集中删除元素
- 从嵌套在std::映射中的std::列表中删除元素的最佳方式
- 从矢量中删除元素后出现隔离错误
- 如何使用remove_if从矢量中删除元素
- 如何从使用 for 循环中的矢量大小的矢量中删除元素
- C++映射不删除元素
- 如何从标准::元组中删除元素?
- 在动态数组中添加/删除C++元素
- 如何通过比较彼此的成员从QStringList中删除元素
- 如何修复从矢量中删除元素的错误?
- 从 std::set 中删除元素,同时在 C++17 中迭代该元素
- 使用remove_if从矢量中删除元素
- 用C++从三维矢量中删除元素
- 从对象数组中删除元素
- 如何在不使用 vector::erase() 的情况下编写自定义 Vector 方法来删除元素?
- C++ - 按自定义数据类型向量的值删除元素
- 从任意容器中廉价删除元素的惯用方法?
- 从数组中删除元素不起作用的函数
- 删除元素 BST
- 从向量中删除元素时未处理的异常