关于list容器与vector容器中的erase操作
来源:互联网 发布:雅思写作书籍推荐知乎 编辑:程序博客网 时间:2024/05/21 17:30
# include<iostream>
# include<vector>
# include<list>
using namespace std;
void main()
{
int ia[]={0,1,1,2,3,5,8,13,21,55,89};
vector<int> v(ia,ia+11);
list<int> l(ia,ia+11);
cout<<" Before erase,the elements of v are:"<<endl;
for(vector<int>::iterator it=v.begin();it!=v.end();it++)
cout<<*it<<" ";
cout<<"\n Before erase,the elements of l are:"<<endl;
for(list<int>::iterator it1=l.begin();it1!=l.end();it1++)
cout<<*it1<<" ";
for(vector<int>::iterator it2=v.begin();it2!=v.end();it2++)
{
if(*it2%2==0)
{
it2=v.erase(it2);
}
}
for(list<int>::iterator it3=l.begin();it3!=l.end();it3++)
{
if(*it3%2==1)
{
it3=l.erase(it3);
--it3;
}
}
cout<<"\n After erase,the elements of v are:"<<endl;
for(vector<int>::iterator it4=v.begin();it4!=v.end();it4++)
cout<<*it4<<" ";
cout<<"\n After erase,the elements of l are:"<<endl;
for(list<int>::iterator it5=l.begin();it5!=l.end();it5++)
cout<<*it5<<" ";
cout<<endl;
# include<vector>
# include<list>
using namespace std;
void main()
{
int ia[]={0,1,1,2,3,5,8,13,21,55,89};
vector<int> v(ia,ia+11);
list<int> l(ia,ia+11);
cout<<" Before erase,the elements of v are:"<<endl;
for(vector<int>::iterator it=v.begin();it!=v.end();it++)
cout<<*it<<" ";
cout<<"\n Before erase,the elements of l are:"<<endl;
for(list<int>::iterator it1=l.begin();it1!=l.end();it1++)
cout<<*it1<<" ";
for(vector<int>::iterator it2=v.begin();it2!=v.end();it2++)
{
if(*it2%2==0)
{
it2=v.erase(it2);
}
}
for(list<int>::iterator it3=l.begin();it3!=l.end();it3++)
{
if(*it3%2==1)
{
it3=l.erase(it3);
--it3;
}
}
cout<<"\n After erase,the elements of v are:"<<endl;
for(vector<int>::iterator it4=v.begin();it4!=v.end();it4++)
cout<<*it4<<" ";
cout<<"\n After erase,the elements of l are:"<<endl;
for(list<int>::iterator it5=l.begin();it5!=l.end();it5++)
cout<<*it5<<" ";
cout<<endl;
}
注意vector与list容器的erase操作是不同的,之所以这样是因为对于vector容器来说,使用erase操作时,迭代器当前指向的元素以及后面的元素均失效,后边的所有元素均要向前移动,而list容器的erase操作不需要移动,它只需删除当前点就可以。erase操作返回的是删除的当前点的下一个元素的迭代器,因此vector容器不需要再减,list需要执行自减操作,因为当前的迭代器已经失效。因为vector是中的元素是连续存储的,而list中的不是,list类似于链表结构。
- 关于list容器与vector容器中的erase操作
- 关于List容器的erase
- list、vector、map容器erase的区别
- STL vector等容器erase操作
- vector::erase():容器删除
- 删除vector容器中的对象元素的三种方法:pop_back, erase与remove算法
- 删除vector容器中的对象元素的三种方法:pop_back, erase与remove算法
- C++ vector容器erase操作后iterate失效真相
- 【C++】vector容器和list容器中使用单个迭代器的erase函数学习笔记
- 容器list使用之erase
- 容器list使用之erase
- 容器list使用之erase
- 容器list使用之erase
- 容器list使用之erase
- 容器list使用之erase
- 容器list使用之erase
- 删除容器(vector、list)中的iterator
- STL顺序容器vector与list
- c# 测试IP是否连通
- 操作系统_再识(kobject,kset,子系统层次结构)
- 用tftp的方式在u_boot下 烧写uImage内核
- OperationalError: FATAL: Ident authentication failed for user “postgres”
- 安全运营(SOC)概述
- 关于list容器与vector容器中的erase操作
- 操作系统_再识(linux设备管理文件系统-devfs与udev)
- JpcapHandler——Jpcap抓包处理
- FBReader编译导入eclipse
- 在 Java 的泛型类型中使用通配符
- 使用Flume NG构建数据收集系统(第一部分 Flume介绍)
- 关于char转换成LPCWSTR的问题
- HDU3143Speedy Escape 最短路+二分+搜索
- eclipse项目名前出现红色感叹号,小红叉解决