C++向量 vector_数组


需要包含头文件, #include  <vector>   

using namespace std;

vector 容器与数组相比其优点在于它能够根据需要随时自动调整自身的大小以便容下所要放入的元素


vector<int> arr;  //创建一个可以容纳整数值的动态数组
vector<int> a1(10); //声明一个初始大小为10的向量
vector<int> a(10, 1); //声明一个初始大小为10且初始值都为1的向量
vector<int> b(a); //声明并用向量a初始化向量b
vector<int> b2=a; //声明并用向量a初始化向量b2
vector<int> b1(a.begin(), a.begin() + 3); //将a向量中从第0个到第2个(共3个)作为向量b1的初始值
vector<int> b3(a.begin(), a.end()); //将a向量中从第0个到最后一个作为向量b3的初始值
int n[] = { 1, 2, 3, 4, 5 };
vector<int> a2(n, n + 5); //将数组n的前5个元素作为向量a2的初值
vector<int> a3(&n[1], &n[4]); //将n[1] - n[4]范围内的元素作为向量a3的初值;顾头不顾尾

int x = a2[0];//返回指定序号的元素值
x = a2.at(0);//返回指定序号的元素值
x=a2.size(); //返回数组元素的总个数;0表示数组为空
x= a2.front(); //返回数组的第一个元素的值
x= a2.back(); //返回数组的最后一个元素的值
a.clear(); //清空数组,即把里面的所有元素都删除
vector<int>::iterator iter; //定义一个迭代器变量;可以理解成指针
iter=a2.begin(); //返回数组第一个数的下标;返回值类型:迭代器
a2.end(); //返回数组最后一个数的下标;返回值类型:迭代器
bool bl= a2.empty(); //判断数组是否为空,如果为空则返回true,非空(有元素)则返回false
//a2.swap(b); //两个动态数组的元素互换
//swap(a2, b); //两个动态数组的元素互换
a2.push_back(30); //在尾部插入一个元素
a2.insert(a2.begin() + 1, 888); //在下标1的位置插入元素
a2.insert(a2.begin() + 2, 3, 999); ////在下标2的位置插入3个元素
a2.insert(a2.end() , 66); //在尾部插入一个元素
a2.insert(a2.end(),2, 55); //在尾部插入n个元素
int nn[] = { 15,25,35,45,55,65,75 };
a2.insert(a2.end(), nn+1, nn+5); //插入普通数组中的元素
//参数1 插入位置
//参数2 普通数组的第1个元素开始
//参数3 普通数组的第5个元素结束,顾头不顾尾
a2.pop_back(); //删除动态数组的最后一个元素
int k=0,l=1,r=1;
a2.erase(a2.begin() + k); //删除动态数组的下标为 k 的元素,返回下一个位置的迭代器
a2.erase(a2.begin() + l, a2.end() - r); //删除动态数组;从小标l开始,尾部留下r个

//遍历方法一,使用索引下标来遍历
for (int i=0;i<a2.size();i++)
{
x = a2[i];
}

//遍历方法二,使用迭代器来遍历
for (iter=a2.begin();iter!=a2.end();++iter)
{
x = *iter;
}
a2[0]=10;给指定序号赋值