1.Vector容器简介

  • vector是将元素置于一个动态数组中加以管理的容器。
  • vector可以随机存取元素(支持索引值直接存取, 用[]操作符或at()方法,这个等下会详讲)。
  • vector尾部添加或移除元素非常快速。但是在中部或头部插入元素或移除元素比较费时。

2.vector对象的默认构造

vector采用模板类实现,vector对象的默认构造形式

vector<T> vecT;

vector<int> vecInt;          //一个存放int的vector容器。

vector<float> vecFloat;     //一个存放float的vector容器。

3.vector对象的带参数构造

  • vector(beg,end);    //构造函数将[beg, end)区间中的元素拷贝给本身。注意该区间是左闭右开的区间。
  • vector(n,elem);   //构造函数将n个elem拷贝给本身。
  • vector(const vector &vec);  //拷贝构造函数
 #include <iostream>
using namespace std;
#include <vector> void objPlay()
{
int iArray[] = { , , , , };
vector<int> vecIntA(iArray, iArray + );
vector<int> vecIntB(vecIntA.begin(), vecIntA.end()); //用构造函数初始化容器vecIntB
vector<int> vecIntB(vecIntA.begin(), vecIntA.begin() + );
vector<int> vecIntC(, ); //此代码运行后,容器vecIntB就存放3个元素,每个元素的值是9。
vector<int> vecIntD(vecIntA);
}
int main()
{
objPlay();
system("pause");
}

4.vector的赋值

  • vector.assign(beg,end);    //将[beg, end)区间中的数据拷贝赋值给本身。注意该区间是左闭右开的区间。
  • vector.assign(n,elem);  //将n个elem拷贝赋值给本身。
  • vector& operator=(const vector  &vec);          //重载等号操作符
  • vector.swap(vec);  // 将vec与本身的元素互换。
void objPlay2()
{
vector<int> vecIntA, vecIntB, vecIntC, vecIntD;
int iArray[] = { , , , , };
vecIntA.assign(iArray, iArray + );
vecIntB.assign(vecIntA.begin(), vecIntA.end()); //用其它容器的迭代器作参数。
vecIntC.assign(, );
vecIntD = vecIntA;
vecIntA.swap(vecIntD);
}

5.vector的大小

  • vector.size();         //返回容器中元素的个数
  • vector.empty();     //判断容器是否为空
  • vector.resize(num);   //重新指定容器的长度为num,若容器变长,则以默认值填充新位置。如果容器变短,则末尾超出容器长度的元素被删除。
  • vector.resize(num, elem);  //重新指定容器的长度为num,若容器变长,则以elem值填充新位置。如果容器变短,则末尾超出容器长度的元素被删除。
void objPlay3()
{
vector<int> vecInt;
int iArray[] = { , , };
int iSize = vecInt.size(); //iSize == 3;
bool bEmpty = vecInt.empty(); // bEmpty == false;
vecInt.resize(); //此时里面包含1,2,3,0,0元素。
vecInt.resize(, ); //此时里面包含1,2,3,0,0,3,3,3元素。
vecInt.resize(); //此时里面包含1,2元素。
}

6.vector末尾的添加移除操作

  • vector.push_back();//向容器的尾部插入元素
  • vector.pop_back();//从容器的尾部弹出元素
void objPlay4()
{
vector<int> vecInt;
vecInt.push_back(); //在容器尾部加入一个元素
vecInt.push_back();
vecInt.push_back();
vecInt.push_back();
vecInt.push_back();//此时容器有5个元素,1,3,5,7,9
vecInt.pop_back(); //弹出尾部的一个元素
vecInt.pop_back(); //此时容器只有3个元素,1,3,5
}

7.vector的数据随机存取

  • vec.at(idx);    //返回索引idx所指的数据,如果idx越界,抛出out_of_range异常。
  • vec[idx];          //返回索引idx所指的数据,越界时,运行直接报错
void objPlay5()
{
int iArray[] = { , , ,, };
vector<int> vecInt(iArray,iArray+); //包含1 ,3 ,5 ,7 ,9
vecInt.at() == vecInt[]; //
vecInt.at() = ; // 或 vecInt[2] = 8; int iF = vecInt.front(); //iF==1
int iB = vecInt.back(); //iB==9
vecInt.front() = ; //vecInt包含{11,3,8,7,9}
vecInt.back() = ; //vecInt包含{11,3,8,7,19}
}

8.vector的插入

  • vector.insert(pos,elem);   //在pos位置插入一个elem元素的拷贝,返回新数据的位置。
  • vector.insert(pos,n,elem);   //在pos位置插入n个elem数据,无返回值。
  • vector.insert(pos,beg,end);   //在pos位置插入[beg,end)区间的数据,无返回值
void objPlay6()
{
vector<int> vecA;
vector<int> vecB; vecA.push_back();
vecA.push_back();
vecA.push_back();
vecA.push_back();
vecA.push_back(); vecB.push_back();
vecB.push_back();
vecB.push_back();
vecB.push_back(); vecA.insert(vecA.begin(), ); //{11, 1, 3, 5, 7, 9}
vecA.insert(vecA.begin() + , , ); //{11,33,33,1,3,5,7,9}
vecA.insert(vecA.begin(), vecB.begin(), vecB.end()); //{2,4,6,8,11,33,33,1,3,5,7,9}
}

9.vector的删除

  • vector.clear();      //移除容器的所有数据
  • vec.erase(beg,end);  //删除[beg,end)区间的数据,返回下一个数据的位置。
  • vec.erase(pos);    //删除pos位置的数据,返回下一个数据的位置。
void objPlay7()
{
vector<int> vecInt;
vecInt.push_back();
vecInt.push_back();
vecInt.push_back();
vecInt.push_back();
vecInt.push_back();//此时容器元素是1,3,5,7,9
vector<int>::iterator itBegin = vecInt.begin() + ;
vector<int>::iterator itEnd = vecInt.begin() + ;
vecInt.erase(itBegin, itEnd); //删除后 1,5,7,9(左闭右开)
for (vector<int>::iterator it = vecInt.begin(); it != vecInt.end();) //小括号里不需写 ++it
{
if (*it == )
{
it = vecInt.erase(it); //以迭代器为参数,删除元素3,并把数据删除后的下一个元素位置返回给迭代器 ,此处不能it++,因为删除后迭代器自动后移
}
else
{
++it;
}
}
//删除vecInt的所有元素
vecInt.clear(); //容器为空
}

10.迭代器基本原理

  • 迭代器是一个可遍历STL容器内全部或部分元素的对象。
  • 迭代器指出容器中的一个特定位置。
  • 迭代器就如同一个指针。
  • 迭代器提供对一个容器中的对象的访问方法,并且可以定义了容器中对象的范围。

迭代器的分类

  输入迭代器:也有叫法称之为“只读迭代器”,它从容器中读取元素,只能一次读入一个元素向前移动,只支持一遍算法,同一个输入迭代器不能两遍遍历一个序列。

  输出迭代器:也有叫法称之为“只写迭代器”,它往容器中写入元素,只能一次写入一个元素向前移动,只支持一遍算法,同一个输出迭代器不能两遍遍历一个序列。

  正向迭代器:组合输入迭代器和输出迭代器的功能,还可以多次解析一个迭代器指定的位置,可以对一个值进行多次读/写。

  双向迭代器:组合正向迭代器的功能,还可以通过--操作符向后移动位置。

11.双向迭代器与随机访问迭代器

双向迭代器支持的操作:it++,  ++it,    it--,   --it,*it, itA = itB

随机访问迭代器支持的操作:it+=i, it-=i, it+i(或it=it+i),it[i]

void objPlay8()
{
vector<int> vecInt;
vecInt.push_back();
vecInt.push_back();
vecInt.push_back();
vecInt.push_back();
vecInt.push_back();//此时容器元素是1,3,5,7,9
for (vector<int>::iterator it = vecInt.begin(); it != vecInt.end(); ++it)
{
int iItem = *it;
cout << iItem; //或直接使用 cout << *it;
}
//打印出1 3 5 7 9
for (vector<int>::reverse_iterator rit = vecInt.rbegin(); rit != vecInt.rend(); ++rit) //注意,小括号内仍是++rit
{
int iItem = *rit;
cout << iItem; //或直接使用cout << *rit;
}
//打印出9, 7, 5, 3, 1
}

以上的完整版程序如下:

#include <iostream>
using namespace std;
#include <vector> void objPlay()
{
int iArray[] = { , , , , };
vector<int> vecIntA(iArray, iArray + );
vector<int> vecIntB(vecIntA.begin(), vecIntA.end()); //用构造函数初始化容器vecIntB
vector<int> vecIntC(vecIntA.begin(), vecIntA.begin() + );
vector<int> vecIntD(, ); //此代码运行后,容器vecIntB就存放3个元素,每个元素的值是9。
vector<int> vecIntE(vecIntA);
}
void objPlay2()
{
vector<int> vecIntA, vecIntB, vecIntC, vecIntD;
int iArray[] = { , , , , };
vecIntA.assign(iArray, iArray + );
vecIntB.assign(vecIntA.begin(), vecIntA.end()); //用其它容器的迭代器作参数。
vecIntC.assign(, );
vecIntD = vecIntA;
vecIntA.swap(vecIntD);
}
void objPlay3()
{
vector<int> vecInt;
int iArray[] = { , , };
int iSize = vecInt.size(); //iSize == 3;
bool bEmpty = vecInt.empty(); // bEmpty == false;
vecInt.resize(); //此时里面包含1,2,3,0,0元素。
vecInt.resize(, ); //此时里面包含1,2,3,0,0,3,3,3元素。
vecInt.resize(); //此时里面包含1,2元素。
}
void objPlay4()
{
vector<int> vecInt;
vecInt.push_back(); //在容器尾部加入一个元素
vecInt.push_back();
vecInt.push_back();
vecInt.push_back();
vecInt.push_back();//此时容器有5个元素,1,3,5,7,9
vecInt.pop_back(); //弹出尾部的一个元素
vecInt.pop_back(); //此时容器只有3个元素,1,3,5
}
void objPlay5()
{
int iArray[] = { , , ,, };
vector<int> vecInt(iArray,iArray+); //包含1 ,3 ,5 ,7 ,9
vecInt.at() == vecInt[]; //
vecInt.at() = ; // 或 vecInt[2] = 8; int iF = vecInt.front(); //iF==1
int iB = vecInt.back(); //iB==9
vecInt.front() = ; //vecInt包含{11,3,8,7,9}
vecInt.back() = ; //vecInt包含{11,3,8,7,19}
}
void objPlay6()
{
vector<int> vecA;
vector<int> vecB; vecA.push_back();
vecA.push_back();
vecA.push_back();
vecA.push_back();
vecA.push_back(); vecB.push_back();
vecB.push_back();
vecB.push_back();
vecB.push_back(); vecA.insert(vecA.begin(), ); //{11, 1, 3, 5, 7, 9}
vecA.insert(vecA.begin() + , , ); //{11,33,33,1,3,5,7,9}
vecA.insert(vecA.begin(), vecB.begin(), vecB.end()); //{2,4,6,8,11,33,33,1,3,5,7,9}
}
void objPlay7()
{
vector<int> vecInt;
vecInt.push_back();
vecInt.push_back();
vecInt.push_back();
vecInt.push_back();
vecInt.push_back();//此时容器元素是1,3,5,7,9
vector<int>::iterator itBegin = vecInt.begin() + ;
vector<int>::iterator itEnd = vecInt.begin() + ;
vecInt.erase(itBegin, itEnd); //删除了1,5,7,9
for (vector<int>::iterator it = vecInt.begin(); it != vecInt.end();) //小括号里不需写 ++it
{
if (*it == )
{
it = vecInt.erase(it); //以迭代器为参数,删除元素3,并把数据删除后的下一个元素位置返回给迭代器 ,此处不能it++,因为删除后迭代器自动后移
}
else
{
++it;
}
}
//删除vecInt的所有元素
vecInt.clear(); //容器为空
}
void objPlay8()
{
vector<int> vecInt;
vecInt.push_back();
vecInt.push_back();
vecInt.push_back();
vecInt.push_back();
vecInt.push_back();//此时容器元素是1,3,5,7,9
for (vector<int>::iterator it = vecInt.begin(); it != vecInt.end(); ++it)
{
int iItem = *it;
cout << iItem; //或直接使用 cout << *it;
}
//打印出1 3 5 7 9
for (vector<int>::reverse_iterator rit = vecInt.rbegin(); rit != vecInt.rend(); ++rit) //注意,小括号内仍是++rit
{
int iItem = *rit;
cout << iItem; //或直接使用cout << *rit;
}
//打印出9, 7, 5, 3, 1
}
int main()
{
objPlay();
objPlay2();
objPlay3();
objPlay4();
objPlay5();
objPlay6();
objPlay7();
objPlay8();
system("pause");
}

STL学习系列二:Vector容器的更多相关文章

  1. 标准模板库(STL)学习探究之vector容器

    标准模板库(STL)学习探究之vector容器  C++ Vectors vector是C++标准模板库中的部分内容,它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库.vector之所以被 ...

  2. STL学习笔记(二) vector和string

    条款13:vector.string优先于动态分配数组 string是basic_string<char>的类型定义许多string的背后实现都采用了引用计数的技术,可以消除不必要的内存拷 ...

  3. [转]ASP.NET MVC学习系列(二)-WebAPI请求 传参

    [转]ASP.NET MVC学习系列(二)-WebAPI请求 传参 本文转自:http://www.cnblogs.com/babycool/p/3922738.html ASP.NET MVC学习系 ...

  4. MyBatis学习系列二——增删改查

    目录 MyBatis学习系列一之环境搭建 MyBatis学习系列二——增删改查 MyBatis学习系列三——结合Spring 数据库的经典操作:增删改查. 在这一章我们主要说明一下简单的查询和增删改, ...

  5. Maven学习系列二(1-5)

    Maven学习系列二(1-5) 本文转自 QuantSeven 博客,讲解精炼易懂,适合入门,链接及截图如下 http://www.cnblogs.com/quanyongan/category/47 ...

  6. scrapy爬虫学习系列二:scrapy简单爬虫样例学习

    系列文章列表: scrapy爬虫学习系列一:scrapy爬虫环境的准备:      http://www.cnblogs.com/zhaojiedi1992/p/zhaojiedi_python_00 ...

  7. DocX开源WORD操作组件的学习系列二

    DocX学习系列 DocX开源WORD操作组件的学习系列一 : http://www.cnblogs.com/zhaojiedi1992/p/zhaojiedi_sharp_001_docx1.htm ...

  8. RabbitMQ学习系列二-C#代码发送消息

    RabbitMQ学习系列二:.net 环境下 C#代码使用 RabbitMQ 消息队列 http://www.80iter.com/blog/1437455520862503 上一篇已经讲了Rabbi ...

  9. .net reactor 学习系列(二)---.net reactor界面各功能说明

    原文:.net reactor 学习系列(二)---.net reactor界面各功能说明         安装了.net reactor之后,可以在安装目录下找到帮助文档REACTOR_HELP.c ...

随机推荐

  1. 【形式化方法:VDM++系列】4.VDM实战1——铁路费用计算

    又有将近2个月没更新博客了啊!winter holiday简直玩儿疯了的说!结果假期前学习的形式化方法已经忘了大半!面对期末作业,大脑一片空白.于是,赶快复习了一下之前学习的姿势! 这次的主要任务是完 ...

  2. 苹果p12文件--一个苹果证书怎么多次使用(蛋疼,这些问题只有和其他企业合作才会遇到,别人的账号不可能给你,蛋疼....)

    在苹果开发者网站申请的证书,是授权mac设备的开发或者发布的证书,这意味着一个设备对应一个证书,但是99美元账号只允许生成3个发布证书,两个开发证书,这满足不了多mac设备的使用,使用p12文件可以解 ...

  3. sqlmap批量扫描burpsuite请求日志记录

    sqlmap可以批量扫描包含有request的日志文件,而request日志文件可以通过burpsuite来获取, 因此通过sqlmap结合burpsuite工具,可以更加高效的对应用程序是否存在SQ ...

  4. RxJava学习(三)

    变换 所谓变换,就是将事件序列中的对象或整个序列进行加工处理,转换成不同的事件或事件序列. 1) API 首先看一个 map() 的例子: Observable.just("images/l ...

  5. JS中的自执行函数

    本来规划的是2013年,狠狠的将JS学习下,谁知计划赶不上变化,计划泡汤了.13年的我对JS来说可以说是属于跟风,对它的理解和认识也仅仅是皮毛而已,也是因为要完成<ArcGIS API for ...

  6. Source Insight 安装使用

    习惯了在source insight下编辑阅读源码,在linux下用vi总是用不好 ,还是在Ubuntu上用回熟悉的source insight. 在Ubuntu中,安装Windows程序用wine, ...

  7. 【剑指offer】找出数组中出现一次的两个数

    2013-09-08 10:50:46 一个整型数组中,除了两个数字之外,其他数字都出现了2次,找出这两个只出现一次的数字,要求时间复杂度是O(N),空间复杂度是O(1). 小结: 任何数与0异或,结 ...

  8. Regular Ball Super Ball

    Description: Regular Ball Super Ball Create a class Ball. Ball objects should accept one argument fo ...

  9. ListView中使用type需要注意的东西 java.lang.ArrayIndexOutOfBoundsException: length=2; index=2 addScrapView

    ListView中使用type需要注意的东西 在使用ListView时,如果使用了getItemViewType, 记得他的值一定要是从0开始计数的. 且要覆盖getViewTypeCount方法.并 ...

  10. Tomcat 配置问题总结

    本人是一个前端屌丝儿,最近没事研究了一下tomcat的部署问题,一下列几个实用的小技能(直接上干货了,不赘述): 1,路径引用部署 在tomcat目录下的conf/Catalina/localhost ...