vector
头文件
首先要引入头文件 #include <vector> 并使用命名空间:using namespace std;
1、vector的创建
vector<int> vec1; // 创建一个空的vector vector<int> vec2(vec1); // 创建一个vector vec2,并用vec1去初始化vec2 vector<int> vec3(10); // 创建一个含有n个数据的vector vector<int> vec4(10,0); // 创建含有10个数据的vector,并全部初始化为0
2、push_back(),pop_back()添加删除元素
// 在vector尾部添加元素 vec1.push_back(4); vec1.push_back(6); vec1.push_back(8); vec1.push_back(1); vec1.push_back(2); PrintVector(vec1); // 在vector尾部删除元素 vec1.pop_back(); PrintVector(vec1); // 在vector头部添加元素,无法完成,因为vector的数据结构为数组,无法在头部插入元素,否则需要整个数组前移; // 在vector头部删除元素,无法完成,理由同上。
3、[],at(),取某位置的元素值
// 取vector中某位置的元素值 cout << "在1位置的元素值为:" << vec1.at(1) << endl; cout << "在1位置的元素值为:" << vec1[1] << endl;
4、begin(),end(),指向头元素、尾元素的指针
void PrintVector(vector<int> ve) { cout << "Vector中的数据为:"; vector<int>::iterator veIterator; for (veIterator = ve.begin(); veIterator < ve.end(); veIterator++) { cout << *veIterator << " "; } cout << endl; }
5、back(),front(),访问头部元素和尾部元素
// 返回尾部数据的引用 cout << "尾部数据的值为:" << vec1.back() << endl; // 返回头部数据的引用 cout << "头部数据的值为:" << vec1.front() << endl;
6、max_size(),vector的最大容纳量;size():vector当前的元素个数
cout << "vector中的最大容量为:" << vec1.max_size() << endl; cout << "vector中的元素个数为:" << vec1.size() << endl;
7、empty(),判断vector是否为空(返回1:空 0: 非空)
cout << "vector是否为空:" << vec1.empty() << endl;
8、swap():交换两个vector中的值
9、sort():对vector升序排序;reverse():对vector降序排序
// 对vector进行升序排序 sort(vec1.begin(), vec1.end()); PrintVector(vec1); // 对vector进行降序排序 reverse(vec1.begin(), vec1.end()); PrintVector(vec1);
10、[],at():修改元素
// 修改vector中的某个值 vec1[2] = 99; PrintVector(vec1); vec1.at(3) = 88; PrintVector(vec1);
11、erase():删除某个元素
// 删除数组的某个元素 // 为什么要使用iterator来进行定位,因为数组如果要删除一个元素或者插入一个元素,会导致其他元素移动,所以不能直接进行删除 vector<int>::iterator vItera = vec1.begin(); vItera = vItera + 2; vec1.erase(vItera); PrintVector(vec1);
12、insert(): 插入元素
// vector插入某元素,要使用iterator来定位某个位置 vector<int>::iterator vInsert = vec1.begin(); vInsert = vInsert + 2; vec1.insert(vInsert, 777); PrintVector(vec1);
13、clear():清除所有元素
// 清除所有数据 vec1.clear(); PrintVector(vec1); cout << "vector是否为空:" << vec1.empty() << endl;