C++如何删除vector中的指定元素?(代码示例)

C++中遍历删除vector指定值元素不能直接用erase(),否则会跳过下一元素;推荐使用erase-remove惯用法,或手动控制迭代器(erase返回新迭代器),避免for循环中边遍历边erase。

在 C++ 中,不能直接用 erase() 遍历删除 vector 中的指定值元素,否则会跳过下一个元素(因为删除后后续元素前移,而迭代器继续前进)。正确做法是使用 erase–remove 惯用法(Erase-Remove Idiom),或手动控制迭代器。下面给出几种常用、安全、高效的方案。

✅ 推荐:erase-remove 惯用法(最简洁高效)

利用 std::remove 将所有匹配元素“挪到末尾”,再用 erase 一次性删掉它们。注意:remove 不真正删除,只重排;erase 才真正收缩 size。

#include 
#include 
#include 

int main() {
    std::vector v = {1, 2, 3, 2, 4, 2, 5};

    // 删除所有值为 2 的元素
    v.erase(std::remove(v.begin(), v.end(), 2), v.end());

    // 输出: 1 3 4 5
    for (int x : v) std::cout << x << " ";
}

✅ 删除满足条件的元素(用 lambda,支持复杂判断)

当需要按条件删除(如删除所有偶数、大于 10 的数等),用 std::remove_if + lambda:

  • lambda 返回 true 表示“要被移除”
  • 同样配合 erase 完成真实删除
// 删除所有偶数
v.erase(std::remove_if(v.begin(), v.end(), [](int x) { return x % 2 == 0; }), v.end());

✅ 手动遍历 + 迭代器(适合需边删边做逻辑的场景)

如果删除过程中需要访问被删元素、计数、或 break 退出,可用 while 循环 + erase 返回的迭代器(它指向被删元素的下一个):

auto it = v.begin();
while (it != v.end()) {
    if (*it == 2) {
        it = v.erase(it); // erase 返回下一个有效迭代器
    } else {
        ++it;
    }
}

⚠️ 注意:不要写 it++ 后再 erase(it),那会越界;必须用 erase 的返回值更新 it

❌ 常见错误写法(务必避免)

以下代码会导致漏删或越界:

  • for (int i = 0; i → i 递增但元素前移,跳过下一个
  • for (auto it = v.begin(); it != v.end(); ++it) if (*it == 2) v.erase(it);eraseit 失效,再 ++it 是未定义行为

基本上就这些。日常优先用 erase-remove;需要动态逻辑时用 while + erase 返回值。两者都安全、标准、无隐患。