C++ 中的 STL vector 提供了多種刪除元素的方式。以下是幾種常用的方式:
使用 erase 函數(shù):
// 刪除下標為 index 的元素
my_vector.erase(my_vector.begin() + index);
// 刪除從下標 start 到 end 之間的元素
my_vector.erase(my_vector.begin() + start, my_vector.begin() + end);
使用 pop_back 函數(shù):
// 刪除最后一個元素
my_vector.pop_back();
使用 remove 和 erase 函數(shù):
// 移除值為 value 的所有元素
my_vector.erase(std::remove(my_vector.begin(), my_vector.end(), value), my_vector.end());
需要注意的是,以上三種方式可能會導致迭代器失效,因為刪除一個元素后,后面的所有元素會向前移動。如果需要在循環(huán)中刪除元素,可以使用如下方式:
使用 while 循環(huán)和迭代器:
auto it = my_vector.begin();
while (it != my_vector.end()) {
if (some_condition) {
it = my_vector.erase(it); // 刪除元素,并返回下一位迭代器
} else {
++it;
}
}
以上方式可以避免迭代器失效,但是刪除元素的操作可能比其他方式慢,因為需要將后面的元素向前移動。因此,在實際使用時需要權衡選擇。