本文转载自:VC驿站
https://www.cctry.com/thread-290348-1-1.html
1、vector 的的常用基本操作:
vector<int> arr_int;
① arr_int[idx] 或 arr_int.at(idx) //返回动态数组中下标为 idx 的 arr_int[idx] 元素的值
② arr_int.size(); //返回 arr_int 数组元素的总个数
③ arr_int.front(); //返回 arr_int 数组的第一个元素的值
④ arr_int.back(); //返回 arr_int 数组的最后一个元素的值
⑤ arr_int.clear(); //清空 arr_int 数组,即把里面的所有元素都删除
⑥ arr_int.begin(); //返回 arr_int 数组第一个数的下标
⑦ arr_int.end(); //返回 arr_int 数组最后一个数的下标
⑧ arr_int.empty(); //判断 arr_int 数组是否为空,如果为空则返回true,非空(有元素)则返回false
⑨ arr_int.swap(v1); //v1是另一个动态数组,将 arr_int 和 v1 两个动态数组的元素互换
⑩ swap(arr_int, v1); //同⑨
示例代码:
#include <vector>
using namespace std;
int main(int argc, char* argv[])
{
vector<int> arr_int, arr_2;
cout << "arr_int.size() = " << arr_int.size() << endl;
cout << "arr_int.empty() = " << arr_int.empty() << endl;
arr_int.push_back(0);
arr_int.push_back(1);
arr_int.push_back(3);
arr_2 = arr_int;
cout << "arr_int.size() = " << arr_int.size() << endl;
cout << "arr_int.empty() = " << arr_int.empty() << endl;
cout << "arr_int.at(0) = " << arr_int.at(0) << endl;
cout << "arr_int[1] = " << arr_int[1] << endl;
cout << "arr_int.front() = " << arr_int.front() << endl;
cout << "arr_int.back() = " << arr_int.back() << endl;
arr_int.clear();
cout << "arr_int.size() = " << arr_int.size() << endl;
cout << "arr_int.empty() = " << arr_int.empty() << endl;
arr_int.swap(arr_2);
return 0;
}
注意:vector 的下标跟普通数组一致,是从 0 开始的!
备注:代码详细讲解详见视频教程!
2、vector 的动态插入:
vector 支持的动态插入也有多种方式:
①、调用 push_back 在尾部插入一个元素,只能是一个一个插入:arr_int.push_back(3);
②、调用 insert 在下标为1的前面插入一个元素,arr_int.insert(arr_int.begin()+1, 888);
③、调用 insert 在下标为2的前面插入3个888元素,arr_int.insert(arr_int.begin()+2, 3, 888);
③、调用 insert 在下标为2的前面插入N个元素:
vector<int> arr_int, arr_2;
arr_int.push_back(0);
arr_int.push_back(1);
arr_int.push_back(3);
arr_2.push_back(2);
arr_2.push_back(5);
arr_2.push_back(6);
arr_int.insert(arr_int.begin() + 2, arr_2.begin(), arr_2.end());
int sz_int[] = { 4, 7, 9 };
arr_int.insert(arr_int.begin() + 4, sz_int, sz_int + 3);
怎么样?很灵活吧,其实有了上面的 insert 已经可以兼容到各个方面了!
3、vector 的动态删除:
①、arr_int.pop_back(); //删除 arr_int 动态数组的最后一个元素
②、arr_int.erase(v.begin()+k); //删除 arr_int 动态数组的下标为 k 的元素,返回下一个位置的迭代器
③、arr_int.erase(v.begin()+l, v.end()-r); //删除 arr_int 动态数组中下标 [l,v.end()-r) 的元素
4、vector 的遍历:
①、因为是 vector 也是数组,所以可以使用索引下标来遍历,如下:
for (int idx = 0; idx < arr_int.size(); ++idx)
{
int value = arr_int[idx];
cout << "idx = " << idx << ", value = " << value << endl;
}
②、使用迭代器遍历:
for (vector<int>::iterator itor = arr_int.begin(); itor != arr_int.end(); ++itor)
{
int value = *itor;
cout << "value = " << value << endl;
}
5、小作业:
定义一个 int 类型的 vector 动态数组,将以下元素:1, 4, 3, 7, 9, 3, 6, 8, 3, 5, 2, 3, 7 插入到动态数组中。之后,使用 for 循环删除动态数组中的值为 3 的元素,并将结果输出出来!
第47课视频教程下载地址: