时间:2023-02-01 10:28:38 | 栏目:C代码 | 点击:次
#include<iostream>//容器 #include<vector> //算法 #include<iterator>//迭代器
一个代码示例
#include<iostream>//容器 #include<vector> //算法 #include<iterator>//迭代器 using namespace std; int main(int argc, const char* argv[]) { const int SIZE = 6; int array[SIZE] = {1,2,3,4,5,6}; vector<int> v(array,array+SIZE); cout<<"First element:"<<v.front()<<"\n Last element"<<v.back()<<endl; }
定义十个整形元素的向量(其中初值不确定)
vector<int> a(10);
每个元素初值为1;
vector<int> a(10,1);
类似于深拷贝的整体赋值方式
vector<char> a(b); vector<char> a(b.begin(),b.begin+3);//(a的值为0~2个元素)
用数组赋初值(和上面一个有点相似)
vector<int> a(b, b+7);
a.assign(b.begin(),b.begin()+3); //注意!此处,将b 0~2个元素构成的向量赋值给a!与上面不同! a.assign(4,2);// 与vector<int> a(10,1);结果相同
//返回最后一个元素 a.back(); //返回第一个元素 a.front(); //数组返回式 a[i];
a.clear(); a.empty();
//删除最后一个元素 a.pop_back(); //删除一块元素 a.erase(a.begin(),a.begin()+3);
//在最后一个向量后插入一个元素 a.push_back(5); // 插入一段元素(从第一个元素算起,插入3个数,值都为5) a.insert(a.begin(), 3, 5); //用数组插入一段元素(在a的第一个元素的位置插入b的第3个元素到第5个元素) a.insert(a.begin(), b+1,b+6); //从现有向量中选择元素向向量中添加 int a[6] = {1, 2, 3, 4, 5, 6}; vector<int> b; wector<int> c(a, a+4); for(vector<int>::iterator it = c.begin(); it<c.end():it++) { b.push_back(*it); } //从文件读取元素向向量中添加 ifstream in("data.txt"); vector<int> a; for(int i;in>>i) { a.push_back(i); }
a.size(); a.c apacity();
//将元素个数调整至10,多删少补,补的值随机 a.resize(10); //将元素个数调整至10,多删少补,补的值为2 a.resize(10,2); //大容量扩充(不补充值) a.reserve(100);
a.swap(b);
a==b; //还有 != >= <= > <
//从小到大排列 sort(a.begin(), a.end()); //倒置但不排列 reverse(a.begin(),a.end()); //元素复制 copy(a.begin(),a.end(),b.begin()); //从某一区块中查找元素值,返回位置 find(a.begin(),a.end(),10);
下标只能获取已存在的元素,不能进行赋值操作
//错误示例 vector<int> a; for(int i = 0;i<10;i++) a[i] = i;