vector就是一个不定长数组。vector是一个模板类,所以需要用vectir<int>a,或者vector<double>b 这样的方式来声明一个vector。vector<int>a 是一个类似于 int a[] 的整数数组,而 vector<string>a 就是一个类似于 string a[] 的字符串数组。
vector 看上去像是“一等公民”,因为它们可以直接赋值,还可以作为函数的参数或者返回值,而无需像传递数组那样另外用一个变量指定元素的个数。
头文件是 #include<vector> !
以下用 vector<int>a,b,v; 来举例它的各个函数作用。
a.push_back(X);向尾部插入X。
for(int i=0;i<10;i++){
a.push_back(i);
cout<<a[i]<<" ";
}
//0 1 2 3 4 5 6 7 8 9
a.size(); 返回数组大小
cout<<a.size()<<endl;
//10
a.clear(); 清空 a 中所有元素
a.clear();
cout<<a.size();
//0
a.empty(); 判断 a 是否为空
if(a.empty()) cout<<"true"<<endl;
//true
a.pop_back(); 在尾部删除元素
for(int i=0;i<10;i++){
a.push_back(i);
cout<<a[i]<<" ";
}
cout<<endl;
a.pop_back();
for(int i=0;i<a.size();i++)
cout<<a[i]<<" ";
//0 1 2 3 4 5 6 7 8 9
//0 1 2 3 4 5 6 7 8
a.begin(); a 中第一个元素
a.end(); a中最后一个元素
a.rend(); a中逆数第一个(于a.begin() 相同)
a.rbegin(); a中逆数第一个(于a.end() 相同)
b.assign(a.begin(),a.end()); 将 a 中从第一个到最后一个复制给 b
b.assign(4,2); b 中加入4个2
a.erase(1,3); 删除区间 [1,3) 上的数(下标从0开始)
a.erase(x) 删除 x 位置上的数
a.insert(p,x); 在 p 的位置上插入 x
a.insert(p,n,x); 在 p 的位置上插入 n 个x
a.resize(10);将a的现有元素个数调整至10个,多则删,少则补,其值随机
a.resize(10,2);将a的现有元素个数调整至10个,多则删,少则补,其值为2
a.reserve(100);将a的容量扩充至100
a.swap(b);b为向量,将a中的元素和b中的元素整体交换
sort(a.begin(),a.end());大到小排序
reverse(a.begin(),a.end());小到大排序
copy(a.begin(),a.end(),b.begin()+1);将 a 中所有元素复制到 b 中,并复制到b中 1 的位置开始,b 中 1 (包括1)中将其覆盖
find(a.begin(),a.end(),10); 查找 a 中是否有10,有则返回第一个位置
a.count(x); 返回a 中x的个数
a.at(p); 访问p 位置的元素,与 a[p] 作用相同
a.shrink _to_fit();将内存减少到等于当前元素实际所使用的大小
a.capacity(); 返回a在内存中总共可以容纳的元素个数,不是 a 的大小
网友评论