STL之vector的使用三(vector的删除)

删除指定元素

1 vector<double> v1;
2 //….初始化代码
3 vector<double>:: iterator i = find( v1.begin(),v1.end(), 3.0 );
4 if( i != v1.end() )
5 {
6 v1.erase(i);
7 }

这样就真的删除了么指定的元素了么?没有。其实只是内部的元素作了移动,vector的删除的时间复杂度是很高的。所以选择容器的时候,如果需要频繁在中间插入和删除元素,那选择vector就会影响效率了。

注意:插入或者删除操作会使得迭代器失效。
原则:使用erase-remove惯用法删除元素

1 v1.erase( remove(v1.begin(), v1.end(), 3.0),  v1.end() );

原创文章,转载请注明: 转载自C/C++程序员之家

本文链接地址: STL之vector的使用三(vector的删除)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值