【STL】vector删除元素,queue删除元素

本文介绍了C++中vector和queue容器元素的删除方法。vector可通过pop_back()、erase()和remove()删除元素,pop_back()删最后一个,erase()可删指定元素或范围,remove()一般不改变容器大小。queue自身不支持clear,可通过空队列赋值、遍历出队、swap方法实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

【vector】

向量容器的成员函数pop_back()可以删除最后一个元素。

而函数erase()可以删除由一个iterator指出的元素,也可以删除一个指定范围的元素。

还可以采用通用算法remove()来删除vector容器中的元素,不同的是,采用remove一般情况下不会改变容器的大小,而pop_back()与erase()等成员函数会改变容器的大小。

【例子】
remove(begin(), end(), val): 
返回新的end()迭代器但是不改变原来数组的end()迭代器的值,将范围内值等于val的元素用后一个元素替代。原先数组中 新的end()至原end()范围内的值仍为原来数组的值,但是这部分状态不可靠。


erase():  //参数:填迭代器或者迭代器,长度 
返回下一个元素的迭代器且改变原来数组的end()迭代器的值,将范围内的值用下一个元素替代。
区别: 
返回值不同,是否改变了原数组的end()的值。
--------------------- 

【queue】

C++中的queue自身是不支持clear操作的,但是双端队列deque是支持clear操作的。

方法一
直接用空的队列对象赋值

queue<int> q1;
// process
// ...
q1 = queue<int>();


方法二
遍历出队列

while (!Q.empty()) Q.pop();


方法三
使用swap,这种是最高效的,定义clear,保持STL容器的标准。

void clear(queue<int>& q) {
    queue<int> empty;
    swap(empty, q);
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值