1.vector向量
(1)头文件<vector>
(2)构造函数
vector<int>a(3); //int型vector,包含3个元素 vector<int>b(3,9); //int型vector,包含3个元素且每个元素都是9 vector<int>c(a); //复制a到c
(3)常用函数
p.push_back(t); 在容器的最后添加一个值为t的数据,容器的size变大 p.size(); 返回容器中数据的个数,size返回相应vector类定义的size_type的值 p.empty() 判断vector是否为空,如果是则返回true,否则,返回false p.pop_back() 删除容器的末元素,并不返回该元素 p.clear(); 清空向量中所有元素 p.front(); 返回首元素的引用 p.at(pos); 返回pos位置元素的引用 p.back(); 返回尾元素的引用 p.begin(); 返回向量头指针,指向第一个元素 p.end(); 返回向量尾指针,指向向量最后一个元素的下一个位置 p.rbegin(); 反向迭代器,指向最后一个元素 p.rend(); 反向迭代器,指向第一个元素之前的位置
2.示例
#include <iostream>
#include <vector>
using namespace std;
class A
{
};
int main()
{
//————定义示例
vector<int>aa;
vector<A>bb;
vector<A*>cc;
//————————————
vector<int>a(3);//int型vector,包含3个元素
for(vector<int>::iterator it = a.begin(); it != a.end(); it++)
*it = 1;
vector<int>b(3,9);//int型vector,包含3个元素且每个元素都是9
vector<int>c(a);//复制a到c
int z[] = {2,4,6};
vector<int>d(z,z + 3);//创建d
//打印vectorA,此处也可以用下面注释内的代码来输出vector中的数据
cout<<"a:"<<endl;
for(long long int i = 0; i < a.size(); i++)
{
cout<<a[i]<<" ";
}
cout<<endl;
for(vector<int>::iterator it = a.begin(); it != a.end(); it++)
{
cout<<*it<<" ";
}
cout<<endl;
cout<<"b:"<<endl;
for(vector<int>::iterator it = b.begin(); it != b.end(); it++)
{
cout<<*it<<" ";
}
cout<<endl;
cout<<"c:"<<endl;
for(vector<int>::iterator it = c.begin(); it != c.end(); it++)
{
cout<<*it<<" ";
}
cout<<endl;
cout<<"d:"<<endl;
for(vector<int>::iterator it = d.begin(); it != d.end(); it++)
{
cout<<*it<<" ";
}
cout<<endl;
//增加a中元素
for(int i = 0; i < 3; i++)
a.push_back(i);
cout<<"a:"<<endl;
for(long long int i = 0; i < a.size(); i++)
{
cout<<a[i]<<" ";
}
cout<<endl;
for(long long int i = 0; i < a.size(); i++)
{
cout<<a.at(i)<<" ";
}
cout<<endl;
for(vector<int>::iterator it = a.begin(); it != a.end(); it++)
{
cout<<*it<<" ";
}
cout<<endl;
//修改向量中的数据
cout<<"通过数组修改a中第一个元素为10"<<endl;
a[0] = 10;
for(vector<int>::iterator it = a.begin(); it != a.end(); it++)
{
cout<<*it<<" ";
}
cout<<endl;
cout<<"通过引用修改a中第一个元素为11"<<endl;
int &m = a[0];
m = 11;
for(vector<int>::iterator it = a.begin(); it != a.end(); it++)
{
cout<<*it<<" ";
}
cout<<endl;
cout<<"通过引用修改a中第一个元素为11"<<endl;
vector<int>::iterator it1 = a.begin();
*it1 = 12;
for(vector<int>::iterator it = a.begin(); it != a.end(); it++)
{
cout<<*it<<" ";
}
cout<<endl;
//删除向量中的数据
vector<int>e;
for(int i = 1; i < 11; i++)
e.push_back(i);
cout<<"e:"<<endl;
for(vector<int>::iterator it = e.begin(); it != e.end(); it++)
{
cout<<*it<<" ";
}
cout<<endl;
//删除第一个元素
e.erase(e.begin());
for(vector<int>::iterator it = e.begin(); it != e.end(); it++)
{
cout<<*it<<" ";
}
cout<<endl;
//删除第1--3元素
e.erase(e.begin(),e.begin() + 3);
for(vector<int>::iterator it = e.begin(); it != e.end(); it++)
{
cout<<*it<<" ";
}
cout<<endl;
//删除最后一个元素
e.pop_back();
for(vector<int>::iterator it = e.begin(); it != e.end(); it++)
{
cout<<*it<<" ";
}
cout<<endl;
return 0;
}