vector 是“变长数组”,即“长度根据需要而自动改变的数组”。
#include <vector>
vector<typename> name;
这里的typename可以是任何基本类型,如:int、double、char、结构体、STL标准容器等。
【注意】如果typename也是STL容器,定义的时候要记得在>>符号之间加上空格。
vector<int> name;
vector<node> name; // node是结构体的类型
vector<vector<int> > name; // >>之间要加空格
vector<typename> Arrayname[arraySize];
这样 Arrayname[0]~Arrayname[arraySize-1]
中每一个都是一个vector容器。一般用这种方式实现图的边存储。
与vector<vector<int> > name
不同的是,这种写法其中一维长度已经固定为 arraySize,另一维才是“变长”的。
和访问普通数组一样,对一个定义为vector<typename> vi
的 vector 容器来说,直接访问vi[index]
即可,这里下标是从0到vi.size()-1。
定义迭代器:
vector<typename>::iterator it;
这样可以得到迭代器 it,可以通过指针*it来访问 vector 里的元素。
添加容器元素:
vector<int> vi;
for(int i=1;i<=5;++i)
vi.push_back(i); // 在末尾添加元素i
可以通过类似下标和指针访问数组的方式来访问容器内的元素:
vector<int>::iterator it = vi.begin(); // vi.begin()取vi的首元素地址,而it指向这个地址
for(int i=0;i<5;++i)
printf("%d ", it[i])); // 1 2 3 4 5
【注意】vi[i]
和*(vi+i)
、*(vi.begin()+i)
、vi.begin()[i]
是等价的。
end()
函数是取尾元素地址的下一个地址,作为迭代器末尾的标志,不存储任何元素。
for(vector<int>::iterator it = vi.begin();it!=vi.end();it++)
printf("%d ", *it); // 1 2 3 4 5
vector 的迭代器不支持it<vi.end()
写法,因此循环条件只能用it!=vi.end()
for(vector<int>::reverse_iterator it = vi.rbegin();it!=vi.rend();it++)
printf("%d ", *it); // 5 4 3 2 1
在 vector 后面添加一个元素 x,时间复杂度为 O(1)。
vector<int> vi;
for(int i=1;i<=3;++i) vi.push_back(i); // 将1、2、3依次插入vi末尾
删除 vector的尾元素,时间复杂度为 O(1)。
vector<int> vi;
for(int i=1;i<=3;++i) vi.push_back(i); // 将1、2、3依次插入vi末尾
vi.pop_back(); // 删除vi的尾元素3
获得 vector 中元素的个数,时间复杂度为 O(1)。size()返回的是 unsigned 类型。
vector<int> vi;
for(int i=1;i<=3;++i) vi.push_back(i); // 将1、2、3依次插入vi末尾
printf("%d\n", vi.size()); //3
清空 vector 中的所有元素,时间复杂度为 O(N)。
vector<int> vi;
for(int i=1;i<=3;++i) vi.push_back(i); // 将1、2、3依次插入vi末尾
vi.clear();
insert(it, x)用来向 vector 的任意迭代器 it 处插入一个元素 x,时间复杂度 O(N)。
vector<int> vi;
for(int i=1;i<=5;++i) vi.push_back(i); // 此时为1 2 3 4 5
vi.insert(vi.begin()+2, -1); // 将-1插入vi[2]的位置,此时为1 2 -1 3 4 5
① 删除单个元素
erase(it)
即删除迭代器为it处的元素.
vector<int> vi;
for(int i=5;i<=9;++i) vi.push_back(i); // 此时为5 6 7 8 9
vi.erase(vi.begin()+3); // 删除8,此时为5 6 7 9
② 删除一个区间内所有元素
mp.erase(first, last)
即删除左闭右开区间[first, last)内所有元素。
vector<int> vi;
for(int i=5;i<=9;++i) vi.push_back(i); // 此时为5 6 7 8 9
vi.erase(vi.begin()+1, vi.begin()+4); // 删除vi[1]、vi[2]、vi[3],此时为5 9
如果要删除这个 vector 内的所有元素,正确的写法应该是vi.erase(vi.begin(), vi.end()),vi.end()
就是尾元素地址的下一个地址。更方便的是使用vi.clear()
。
返回是否 vector 为空。
vector<int> vi;
for(int i=1;i<=5;++i)
vi.push_back(i);
if (g1.empty() == false)
cout << "Vector is not empty";
else
cout << "Vector is empty";
结果为:
Vector is not empty
用于给 vector 赋值
① 当参数为数值的时候
assign(int x, typename y)
就是给 vector 赋值 为 x 个 y。此时会改变 vector 的 size()
vector<int> vt;
vt.assign(7, 4);
for (int i = 0; i < vt.size(); i++){
cout<<vt[i]<<" ";
}
cout<<endl;
vt.assign(5, 3);
for(int i=0; i<vt.size(); i++){
cout<<vt[i]<<" ";
}
cout<<endl;
结果:
4 4 4 4 4 4 4
3 3 3 3 3
② 当参数为迭代器或者指针时
assign(typename* x, typename* y)
,就是将[x, y)范围内的内容给 vector 初始化,会改变 size()。
vector<int> v1; int a[] = { 1, 2, 3 }; // assign first 2 values v1.assign(a, a + 2); cout << "Elements of vector1 are\n"; for (int i = 0; i < v1.size(); i++) cout << v1[i] << " "; vector<int> v2; // assign first 3 values v2.assign(a, a + 3); cout << "\nElements of vector2 are\n"; for (int i = 0; i < v2.size(); i++) cout << v2[i] << " ";
结果为:
Elements of vector1 are
1 2
Elements of vector2 are
1 2 3
vector<int> v; v.assign(7, 100); cout << "Size of first: " << int(v.size()) << '\n'; cout << "Elements are\n"; for (int i = 0; i < v.size(); i++) cout << v[i] << " "; // modify the elements v.assign(v.begin(), v.begin() + 3); cout << "\nModified VectorElements are\n"; for (int i = 0; i < v.size(); i++) cout << v[i] << " "; cout<<endl;
结果为:
Size of first: 7
Elements are
100 100 100 100 100 100 100
Modified VectorElements are
100 100 100
③当参数为数组时
assign({x1, x2, ...})
直接将 vector 初始化为该数组
vector<int> v;
// Initialize v with an initialization list
v.assign({ 1, 2, 3 });
cout << "The list is:" << endl;
for (auto i = v.begin(); i != v.end(); i++)
{
// Printing 1 2 3 as output
cout << *i << " ";
}
结果为:
The list is:
1 2 3
用于交换两个 vector
vector<int> v1, v2; v1.push_back(1); v1.push_back(2); v2.push_back(3); v2.push_back(4); cout << "Vector 1: "; for (int i = 0; i < v1.size(); i++) cout << v1[i] << " "; cout << "\nVector 2: "; for (int i = 0; i < v2.size(); i++) cout << v2[i] << " "; // Swaps v1 and v2 v1.swap(v2); cout << "\nAfter Swap \nVector 1: "; for (int i = 0; i < v1.size(); i++) cout << v1[i] << " "; cout << "\nVector 2: "; for (int i = 0; i < v2.size(); i++) cout << v2[i] << " ";
结果:
Vector 1: 1 2
Vector 2: 3 4
After Swap
Vector 1: 3 4
Vector 2: 1 2
联系客服