vector容器
功能:vector数据结构和数组非常相似,也称为单端数组
区别:数组是静态空间,vector可以动态扩展
动态扩展:并不是在原空间后续接新空间,而是找更大的内存空间,将原数据拷贝到新空间,释放原空间
vector容器的迭代器是支持随机访问的迭代器
1.vector构造函数
创建vector容器
vector v; //采用模板实现类实现,默认构造函数
vector(v.begin(),v.end()); //将 v[begin(),end()) 左闭右开区间中的元素拷贝给本身
vector(n,elem); //构造函数将n个elem拷贝给本身
vector(const vector &vec); //拷贝构造函数
#include <iostream>
using namespace std;
#include <vector>
void printvector(vector<int>&v)
{
for(vector<int>::iterator t = v.begin();t!=v.end();t++){
cout<<*t<<" ";
}
cout<<endl;
}
void test01()
{
vector<int> v1; //默认构造 无参构造
for(int i=0;i<10;i++){
v1.push_back(i);
}
printvector(v1);
vector<int> v2(v1.begin(),v1.end());//区间方式构造
printvector(v2);
//n个elem方式构造
vector<int> v3(10,100);
printvector(v3);
//拷贝构造
vector<int> v4(v3);
printvector(v4);
}
int main()
{
test01();
return 0;
}
2.vector赋值操作
给vector容器进行赋值
vector&operator=(const vector &vec); //重载等号操作符
assign(beg,end); //将[beg,end)区间中的数据拷贝赋值给本身
assign(n,elem); //将n个elem拷贝赋值给本身
#include <iostream>
using namespace std;
#include <vector>
void printvector(vector<int>&v)
{
for(vector<int>::iterator t = v.begin();t!=v.end();t++){
cout<<*t<<" ";
}
cout<<endl;
}
void test01()
{
vector<int> v1;
for(int i=0;i<10;i++){
v1.push_back(i);
}
printvector(v1);
vector<int> v2;
v2 = v1;
printvector(v2);
vector<int> v3;
v3.assign(v1.begin(),v1.end());
printvector(v3);
vector<int> v4;
v4.assign(10,100);
printvector(v4);
}
int main()
{
test01();
return 0;
}