一、vector的二维数组用法:
有时候我们在代码里会需要用到c语言的二维数组,但是c语言的二维数组会有一些不方便,比如二维数组的大小必须提前确定好,这时候就会想c++里面有没有能代替二维数组的数据结构呢,下面是vector的二维数组简单用法代码:
#include <iostream>
#include <vector>
using namespace std;
int main() {
vector<int> v1;
v1.push_back(1);
v1.push_back(2);
vector<int> v2;
v2.push_back(3);
v2.push_back(4);
vector < vector<int>> v;
v.push_back(v1);
v.push_back(v2);
cout << v[0][0] << endl;//输出1
cout << v[0][1] << endl;//输出2
cout << v[1][0] << endl;//输出3
cout << v[1][1] << endl;//输出4
}
二、压缩一个vector:?
很多时候大量删除数据或者使用reserve()操作vector,导致vector的空间远远大于实际所需要的空间,如果能压缩vector到它实际的大小,就能节省不少的内存空间。
#include <iostream>
#include <vector>
using namespace std;
int main() {
vector<int> v1;
v1.reserve(100);
v1.push_back(1);
v1.push_back(2);
cout << v1.capacity() << endl;//输出100
cout << v1.size() << endl;//输出2
vector<int>(v1).swap(v1);
cout << v1.capacity() << endl;//输出2
cout << v1.size() << endl;//输出2
}
如上代码所示,v1的空间大小为100,但是实际占用的空间为2,我们利用swap()方法可以把v1的大小压缩到它实际需要的大小2。
三、访问vector数据的2种方法的区别:
两种方式分别是:at()函数和[]下标操作。at()主要是多了一个超出范围的检查,如果vector中不存在该位置,则拋出out_of_range异常,更加安全。
|