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

【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);
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值