vector是C++ STL中常用的容器之一,它提供了多种操作来方便地对元素进行增加、删除、查找等操作。本文将针对vector删除某个元素进行详细的阐述。
一、使用erase()方法删除元素
vector提供了erase()方法来删除指定位置的元素,可以通过迭代器或者下标的方式来指定要删除的元素。代码示例如下:
vector v{1, 2, 3, 4, 5};
v.erase(v.begin() + 2); // 删除第3个元素,即3
上述代码中,使用v.begin() + 2来获得第3个元素的迭代器,然后将其传递给erase()方法即可删除该元素。需要注意的是,erase()方法会将被删除元素后面的元素依次向前移动一个位置,因此删除元素的时间复杂度为O(n)。
二、使用remove()方法删除元素
除了使用erase()方法,还可以使用remove()方法来删除vector中的元素。remove()方法并不是真正意义上的删除元素,而是将vector中特定值的元素移动到vector末尾,并返回指向新末尾的迭代器。此时,我们再使用erase()方法,就可以删除移动到末尾的元素。
代码示例如下:
vector v{1, 2, 3, 4, 5};
v.erase(remove(v.begin(), v.end(), 3), v.end()); // 删除3
上述代码中,remove()方法使用起来比较奇特,它接受3个参数,第一个参数是vector的起始迭代器,第二个参数是vector的结束迭代器,第三个参数是要移除的元素的值。remove()方法会找到vector中所有等于第三个参数的元素,并将它们移动到vector末尾,最后返回新的末尾迭代器。我们再使用erase()方法来删除这些移动到末尾的元素,即可完成删除操作。
三、注意事项
在使用erase()方法和remove()方法时,需要注意以下几点:
使用erase()方法删除元素时,需要保证迭代器指向的元素确实存在。 使用remove()方法删除元素时,需要保证vector中确实存在要删除的元素。 删除元素后,vector的size()和capacity()会发生变化。 删除元素操作后,被删除的元素的内存并没有被释放,可以使用shrink_to_fit()方法来缩小vector的容量。四、总结
本文介绍了vector删除元素的两种常见方式,分别是使用erase()方法和remove()方法。需要注意的是,在使用这些方法时需要注意异常情况,以免产生不可预料的错误。同时,删除元素后,还需要注意vector的size()和capacity()的变化,以及释放被删除元素的内存空间。