删除vector容器中的对象元素的三种方法:pop_back, erase与remove算法
来源:互联网 发布:照片打分软件 编辑:程序博客网 时间:2024/05/01 13:54
向量容器的成员函数pop_back()可以删除最后一个元素,而函数erase()可以删除由一个iterator指出的元素,也可以删除一个指定范围的元素。
还可以采用通用算法remove()来删除vector容器中的元素, 不同的是,采用remove 一般情况下不会改变容器的大小,而pop_back()与erase()等成员函数会改变容器的大小。
#include "stdafx.h"
#include <iostream>
#include <vector>
#include <algorithm>
#include <string>
#include <list>
using namespace std;
void PrintInt( const int &nData)
{
cout<<nData<<endl;
}
int _tmain( int argc, _TCHAR* argv[])
{
vector< int > vecInt;
for ( int i=0; i<10;++i)
{
vecInt.push_back(i);
}
cout<< " 向量中的内容为:" <<endl;
for_each(vecInt.begin(),vecInt.end(),PrintInt);
cout<< "vector contains " <<vecInt.size()<< " elements" <<endl;
vecInt.pop_back(); // 删除最后一个元素
cout<< " 删除最后一个元素后,vector contains " <<vecInt.size()<< " elements" <<endl;
vector< int >::iterator k = vecInt.begin();
vecInt.erase(k); // 删除第一个元素
//vecInt.erase(k); // 迭代器k 已经失效,会出错
cout<< " 删除第一个元素后,vector contains " <<vecInt.size()<< " elements" <<endl;
//vecInt.erase(vecInt.begin(),vecInt.end()); // 删除所有元素
//cout<<" 删除所有元素后,vector contains "<<vecInt.size()<<"elements"<<endl; // 输出为0
vector< int >::iterator vecNewEnd =remove(vecInt.begin(),vecInt.end(),5); // 删除元素
cout<< " 删除元素后,vector contains " <<vecInt.size()<< " elements"<<endl;
cout<< " 向量开始到新结束为止的元素:" <<endl;
for_each(vecInt.begin(),vecNewEnd,PrintInt);
cout<< " 向量中的元素:" <<endl;
for_each(vecInt.begin(),vecInt.end(),PrintInt);
return 0;
}
执行结果:
可以看到:remove算法会返回一个指向新的vector的结尾的iterator,从开始到新这个新的结尾(不含新结尾元素)的范围包含了remove操作后剩余的所有元素。还可以看到,删除向量中的元素后,后面的元素都向前移动了。
另外,迭代器用于erase删除元素后,其后会失效,即不能再用该迭代器操作向量。如,例子中的k,当再次用来删除向量的元素后,就会报错。
- 删除vector容器中的对象元素的三种方法:pop_back, erase与remove算法
- 删除vector容器中的对象元素的三种方法:pop_back, erase与remove算法
- 删除vector容器中的对象元素的三种方法:pop_back, erase与remove算法http://www.xuebuyuan.com/1407838.html
- vector删除元素之pop_back(),erase(),remove()
- remove/remove_if算法配合容器的erase方法实现容器删除元素功能
- erase-remove删除容器元素
- C++ 顺序容器的操作(6) 删除元素 erase、clear、pop_back、pop_front
- vector删除元素erase和通用算法remove
- vector 的删除操作pop_back、erase效率对比
- STL容器中元素的删除erase()、remove()
- vector中的删除,erase和remove的小疑惑--【STL】
- vector中的erase方法跟algorithm的remove
- vector::erase():容器删除
- 容器元素的删除erase,size,clear方法的使用
- C++中删除vector容器中元素的三种方法及其区别
- vector 的删除操作pop_back、erase效率对比 http://blog.csdn.net/efeics/article/details/8059690
- 测试对Vector容器,遍历元素删除满足条件元素,而进行Erase()操作的效率
- 关于list容器与vector容器中的erase操作
- cf 815C Karen and Supermarket 树形dp
- 量子计算入门-第一部分
- cookie操作
- Android原生模拟器创建教程
- tlbblist
- 删除vector容器中的对象元素的三种方法:pop_back, erase与remove算法
- 平均查找长度
- 靓丽图像中的一抹——摩尔纹
- ubuntu中文输入法
- 分页的实现
- 缓存策略之LRU实现(基于双链表实现)
- OpenOffice格式转换中文乱码终极解决方案
- Web前端常用问题--1
- 制作如下所示页面。(东北林业大学WEB课程网页)