功能:vector数据结构和数组非常相似,也称为单端数组
vector与普通数组区别:
不同之处:数组是静态空间,vector可以动态扩展
动态扩展:并不是在原空间之后持续新空间,而是找更大的内存空间,然后将原数据拷贝新空间,释放原空间。
创建vector容器:
函数原型:
vector v;//采用模板实现类实现,默认构造函数
vector(v.begin(), v.end());//将v[begin(),end())区间中的元素拷贝给本身前闭区间后开区间
vector(n,elem);//构造函数将n个elem拷贝给本身
vector(const vector &vec)//拷贝构造函数
vector赋值操作:
函数原型:
vector& operator = (const vector &vec);//重载等号操作符
assign(beg,end);//将[beg,end]曲建忠的数据拷贝复制给本身
assign(n,elem)//将n个elem拷贝复制给本身
#include "pch.h"
#include <iostream>
#include<vector>
#include<algorithm>
#include<string>
using namespace std;
void priintvector(vector<int> &v) {
for (vector<int>::iterator it = v.begin(); it != v.end(); it++) {//遍历
cout << *it << "";
}
cout << endl;
}
//vector容器构造
void test01() {
vector<int> v1;
for (int i = 0; i < 10; i++) {
v1.push_back(i);
}
priintvector(v1);
//通过区间方式进行构造
vector<int>v2(v1.begin(), v1.end());
priintvector(v2);
//n个elem方式构造
vector<int>v3(10, 100);//10个100
priintvector(v3);
//拷贝构造
vector<int>v4(v3);
priintvector(v4);
//赋值 operator=
vector<int> v2;
v2 = v1;
priintvector(v2);
//assign方式赋值
vector<int> v3;
v3.assign(v1.begin(), v1.end());
priintvector(v3);
//n个ele赋值
vector<int>v4;
v4.assign(10, 100);
priintvector(v4);
}