C++通过改变vector.size()进行迭代
C++ iterating with changing vector.size()
我写了一些可能很幼稚的代码,旨在从向量中删除过于相似的元素。功能很好,但我认为由于向量的动态调整,我有时可能会得到意想不到的结果。
for (size_t i = 0 ; i < vec.size(); i++) {
for(size_t j = i+1; j < vec.size(); j++) {
if(norm(vec[i]-vec[j]) <= 20 ) {
vec.erase(vec.begin()+j);
}
}
}
这样做安全吗?当我擦除元素时,我担心I和j是否正确地适应。
您需要更加注意元素的位置。直接用迭代器表达这一点可能比通过索引计算迭代器更容易,比如:
for (auto it = vec.begin(); it != vec.end(); ++it)
{
for (auto jt = std::next(it); jt !=; vec.end(); )
{
if (/* condition */)
{
jt = vec.erase(jt);
}
else
{
++jt;
}
}
}
还要考虑的一件事是,擦除内循环内的元素对外循环的停止条件有什么影响。这也没有问题,因为j
被保证严格大于i
,所以内循环的j < vec.size()
条件将在外循环的i < vec.size()
条件之前被满足,这意味着不存在具有无效索引i
的不安全的vec[i]
访问。
当然,您应该在擦除元素后增加j
,以避免出现经典错误。一个更好的方法是从后面开始遍历向量,但您需要在两个循环中都这样做,以确保i
(一个有效元素)永远不会从i
的外部索引下面擦除。
相关文章:
- 使用std::multimap迭代器创建std::list
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++中带有List类的迭代器Segfault
- 迭代时从向量和内存中删除对象
- 如何在c++迭代器类型中包装std::chrono
- 带过滤器的现代迭代c++集合
- 在c++中检查长方体是否尽可能快地重叠(无迭代)
- C++矢量迭代
- 集合上的输出迭代器:assign和increment迭代器
- Boost Spirit,获取迭代器内部语义动作
- 擦除while循环中迭代的元素
- 实现一个在集合上迭代的模板函数
- 对于set上的循环-获取next元素迭代器
- 在向量内的向量上迭代
- 为什么output_editor Concept不需要output_e迭代器标记
- TSP递归解的迭代形式
- c++17文件系统::recursive_directory迭代器()在mac上没有给出这样的目录,但在windows上
- 迭代器库中的 std::size() 不适用于传递给函数的 C 样式数组
- std :: map :: size()与迭代器不同
- C++通过改变vector.size()进行迭代