答案:C++中vector删除元素主要用erase()和pop_back()。erase()可删除指定位置或范围的元素,如vec.erase(vec.begin()+1)删除第二个元素;pop_back()高效删除末尾元素,时间复杂度O(1);删除特定值需用erase-remove习语,如vec.erase(std::remove(vec.begin(), vec.end(), 2), vec.end())删除所有2,避免迭代器失效。

在C++中,vector删除元素主要通过成员函数 erase() 和 pop_back() 实现。根据删除位置和数量的不同,选择合适的方法能提高代码效率和可读性。
使用 erase() 删除指定位置或范围的元素
erase() 是 vector 中最常用的删除方法,可以删除单个元素或一个元素区间。
• 删除单个元素:传入指向要删除元素的迭代器• 删除一段元素:传入起始和结束迭代器(左闭右开区间)
示例:
std::vector// 删除第二个元素(值为20)
vec.erase(vec.begin() + 1); // 结果: {10, 30, 40, 50}
// 删除从索引2到末尾的元素
vec.erase(vec.begin() + 2, vec.end()); // 结果: {10, 30}
使用 pop_back() 删除最后一个元素
pop_back() 只能删除容器末尾的元素,执行后 size 减1。它不返回值,仅移除最后一个元素。
立即学习“C++免费学习笔记(深入)”;
std::vectorvec.pop_back(); // 结果: {1, 2}
vec.pop_back(); // 结果: {1}
该方法效率高,时间复杂度为 O(1),适合栈式操作。
结合 remove() 和 erase() 删除特定值(erase-remove 习语)
若要删除所有等于某个值的元素,不能直接用 erase 遍历删除(会失效迭代器),应使用标准推荐的 erase-remove 习语。
std::vector// 删除所有值为2的元素
vec.erase(std::remove(vec.begin(), vec.end(), 2), vec.end());
std::remove 将所有匹配值移到末尾,并返回新逻辑结尾的迭代器,再由 erase 统一删除。
如果需要删除满足条件的元素(如大于某值),可用 remove_if 替代 remove:
vec.erase(std::remove_if(vec.begin(), vec.end(), [](int n) { return n > 3; }), vec.end());基本上就这些常用操作。掌握 erase、pop_back 以及 erase-remove 习语,就能高效处理 vector 元素删除问题。注意避免在循环中直接调用 erase 迭代器而不更新,会导致未定义行为。











