C++ 中的 STL vector 提供了多種刪除元素的方式。以下是幾種常用的方式:
使用 erase 函數(shù):
// 刪除下標(biāo)為 index 的元素
my_vector.erase(my_vector.begin() + index);
// 刪除從下標(biāo) start 到 end 之間的元素
my_vector.erase(my_vector.begin() + start, my_vector.begin() + end);
使用 pop_back 函數(shù):
// 刪除最后一個(gè)元素
my_vector.pop_back();
使用 remove 和 erase 函數(shù):
// 移除值為 value 的所有元素
my_vector.erase(std::remove(my_vector.begin(), my_vector.end(), value), my_vector.end());
需要注意的是,以上三種方式可能會(huì)導(dǎo)致迭代器失效,因?yàn)閯h除一個(gè)元素后,后面的所有元素會(huì)向前移動(dòng)。如果需要在循環(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;
}
}
以上方式可以避免迭代器失效,但是刪除元素的操作可能比其他方式慢,因?yàn)樾枰獙⒑竺娴脑叵蚯耙苿?dòng)。因此,在實(shí)際使用時(shí)需要權(quán)衡選擇。