Vector:一个容器,可以构建链表等数据结构
#include<vector> using namespace std;
创建一个vector对象
vector <int> I1; //一个int型的空的vector对象I1 vector <int> I2(500); //包含500个int类型数据的vector对象I2 vector <int> I3(500,1);//把500个数据都赋值1 vector <int> A(B);//把B整体复制到A中 vector <int> A(B.begin(),B.begin()+4);//把B中开始的4个元素(0~3)复制到A
销毁
I.~vector <int> ();
PS:这里的I是之前建立的vector对象名
插入元素:
1、用push_back()在vector尾插入,而不用A[i]=a这种的赋值语句
//添加单个元素 I.push_back(a); //添加多个元素 B[6]={0,1,2,3,4,5}; for(int i=0;i<4;i++) I.push_back(B[i]); //从已有的向量中选择添加 //B是一个int型的vector对象 for(vector <int> ::iterator it=B.begin();it<B.end();it++) I.push_back(*it); //误区 不能用数组下标的方式添加元素,只能用这种方式访问已经存在的元素 for(int i=0;i<6;i++) I[i]=i;//错误 cout<<I[0];//这种是允许的,相当于把[]进行了运算符重载
注意:
如果用vector <int> I(500);这种形式创建了vector对象,那么在push_back()后,push_back的数据在501个
如果想从第一个开始添加,应该采用 vector <int> I;的形式创建
2、用insert在任意位置插入
I.insert(pos,elem); //pos位置插入一个元素elem
I.insert(pos,n,elem) ;//pos位置插入n个元素elem
I.insert(pos,begin,end);//pos位置插入从begin到end(不包含end)的元素
注意这个pos只能是I.begin()+m这种类似形式,而不能单写一个数字
begin与end也是 B.begin()和B.begin()+3这样类似的形式,表示从B.begin()开始的连续三个元素
读取元素
//用下标的方式,同普通数组 //这种方式不安全,常用下一种方法 cout<<I[2]; //at函数 cout<<I.at(2) //I.at(i)等价于I[i],只是更加安全,还会在越界时发出警告
迭代
//如何对一个vector对象实现类似下边的操作呢? //for(int i=0;i<N;i++) // cout<<I[i]; //这涉及到vector的迭代方式 //迭代器的类型写为 vector <int> :: iterator vector <int > B(500,1); for(vector <int>::iterator it=B.begin();it!=B.end();it++) //最后一个B.end()是不能取等号的,相当于大小为6的数组不能取下标为6 cout<<*it; //星号*不能少
删除元素
I.clear(); 删除所有元素
I.pop_back();删除最后一个元素
其他的函数可以参考:
https://blog.csdn.net/qinyuehong/article/details/92837359
https://www.cnblogs.com/-Mr-y/p/7985987.html
原文:https://www.cnblogs.com/LesBlog/p/12563015.html