| 一、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异常,更加安全。 |