问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

使用STL vector的几种清空容器(删除)办法

发布网友 发布时间:2022-04-26 15:00

我来回答

2个回答

热心网友 时间:2022-05-07 20:49

第一种办法使用 clear ,清空元素,但不回收空间
vecInt.clear();
j=vecInt.capacity();//j=512i=vecInt.size();//i=0第二种办法使用 erase循环删除,结果同上vector<int::iteratoriter=vecInt.begin();for(;iter!=vecInt.end();){iter=vecInt.erase(iter);}j=vecInt.capacity();//j=512i=vecInt.size();//i=0
erase在每次操作时,迭代器指针会整体前移1,就是每次都会搬全部数据,所以vector不适合做频繁删除的容器
第三种办法 最简单的使用swap,清除元素并回收内存vector<int().swap(vecInt); //清除容器并最小化它的容量,//vecInt
.swap(vector<int())
; 另一种写法
j=vecInt.capacity();//j=0i=vecInt.size();//i=0该语句是由vector<int(vecInt).swap(vecInt)的变体而来,一下解释引自csdn:
std::vector<T(v).swap(v);的作用相当于:{std::vector<T temp(v);//1
temp.swap(v);//2}第一句产生一个和v内容一模一样的vector,只不过temp的容量是恰好满足其大小的
第二句把v和temp交换
然后temp就自动解析掉了
这样写的作用是:把v的容量缩小到最佳值
该例中执行这句时,

热心网友 时间:2022-05-07 22:07

先写一个循环来迭代容器中的元素,如果迭代元素是要删除的元素,则删除之。
代码如下所示:
vector<int> intContainer;

for(vector<int>::iterator is = intContainer.begin(); it != intContainer.end(); ++it)
{
if ( *it == 25)
intContainer.erase(it);
}。借助remove算法来达到删除元素的目的。

vector<int> intContainer;

size_t before_size = intContainer.size();
remove(intContainer.begin(), intContainer.end(), 25);
size_t after_size = intContainer.size();
运行程序以后发现before_size和after_size是一样的,说明元素并没有被真正删除。写出以上程序,是处于对remove算法的不了解而致。STL中remove算法会将不该删除的元素前移,然后返回一个迭代器,该迭代器指向的是那个应该删除的元素,仅此而已。所以如果要真正删除这一元素,在调用remove之后还必须调用erase,这就是STL容器元素删除的"erase_remove"的惯用法。

vector<int> intContainer;
intContainer.erase( remove(intContainer.begin(), intContainer.end(), 25), intContainer.end());

erase-remove的惯用法适用于连续内存容器,比如vector,deque和string,它也同样适用于list,但是并不是推荐的方法,因为使用list成员函数remove会更高效,
代码如下:
list<int> list_int;
....
list_int.remove(25);
标准关联容器没有remove成员函数,使用STL算法的remove函数时编译同不过。所以上述remove形式对于标准关联容器并不适用。
在这种情况下,解决办法就是调用erase:

map<int, int> mapContainer;
...
mapContainer.erase(25);
对于标准关联容器,这样的元素删除方式是简单有效的,时间复杂度为O(logn).
当需要删除的不是某一个元素,而是具备某一条件的元素的时候,只需要将remove替换成remove_if即可

bool Is2BeRemove(int value)
{
return value < 25;
}
vector<int> nVec;
list<int> nList;
....
nVec.erase(remove_if(nVec.begin(), nVec.end(), Is2BeRemove), nVec.end());
nList.remove_if(Is2BeRemove);
删除容器中具有特定值的元素:
如果容器是ector、string或者deque,使用erase-remove的惯用法。如果容器是list,使用list::remove。如果容器是标准关联容器,使用它的erase成员函数。
删除容器中满足某些条件的元素:
如果容器是ector、string或者deque,使用erase-remove_if的惯用法。如果容器是list,使用list::remove_if。如果容器是标准关联容器,使用remove_copy_if & swap 组合算法。
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
临沂比较有名的男装品牌 呼伦贝尔市悦动网络科技有限公司怎么样? 呼伦贝尔中汇实业有限公司怎么样? 呼伦贝尔油玉不绝电子商务有限公司怎么样? 如何避免wps卡顿? 属鼠的男人找对象是属什么,属鼠的人和什么属相合 96年鼠的姻缘在哪年 属相相合年份运势提升 2024属鼠找对象属什么最佳 黑客攻击网站能报案吗 黑客攻击报案有用吗 五万的恩情两千万还!师傅去世了,郭德纲却依旧照顾她的家人,你怎么看? vector怎样清空 在侯耀文遗产案中,最大的受益者是谁? 侯瓒的介绍 如何清空vector数组 侯瓒是怎么评价郭德纲的? 候瓒才是遗产案最大的赢家,侯耀华疑似被利用,究竟是咋回事? 作为侯耀文的长女,侯瓒是怎么样评价郭德纲的? 侯耀华被冤枉14年,霸占弟弟遗产只是幌子,侯耀文前妻到底都干了啥?_百... 侯耀文39岁大女儿罕见露面,他的家人与德云社什么交情? 侯瓒的个人简介 侯耀文的女儿侯瓒是什么工作 侯瓒素颜气质出众,和郭德纲于谦合照显亲密,他们感情如何? 侯瓒作为侯耀文的长女,她是怎么评价师哥郭德纲的? 老是做梦我使劲拉车,却怎么也拉不动,帮忙解一下 最近一个月中午总是做梦,醒不来,梦里反反复复醒来,其实自己意识到不是真的醒来了,有时候在梦里使劲掐 做梦梦到使劲咬牙控制不了自己 昨天梦见自己使劲的哭有什么征兆吗 做梦梦见自己使劲在跑但是跑的速度还没人家走路快是怎么回事? 做梦使劲推着一本书,作何解 侯瓒做什么工作的 如何删除容器vector里面的所有元素 侯耀文的遗产为什么那么难分,都给儿女不就完了 vector 清除问题 如何正确释放Vector的内存 怎样在c++ 中删除vector最后一个元素 vector怎么清理内存 用memset可以清空vector吗? c++ 如何删除 vector中的第一个元素 VC/MFC vector 如何释放vector中的多余的内存 c++ vector clear() 方法的问题 C++中vector&lt;int&gt;a,b(n,0)什么意思 vector的clear会释放动态内存吗 java vector中clear()与removeAllElements(),arraylist的clear()与new arraylist()有何区别? VC vector clear() 的问题 除了放料猛煮,卤猪肝还有其它的完美做法吗? 猪肝能不能卤着吃 猪肝是贫血人的福音,一定要正确认识猪肝,如何做猪肝? 猪肝是炒着吃好还是做卤猪肝好? 微信被封号了,聊天记录还有吗?