C++vector的用法你都知道嘛

C++vector的用法你都知道嘛

目录

C++vector用法整理

1.头文件

2.vector初始化

3.vector对象的重要操作

1.赋值(assign)

2.返回元素值

3.清空、判断是否为空

4.删除

5.插入

6.返回vector的现存元素个数、共可容纳个数

7.调整元素个数(这个好牛)

8.整体性交换

9.向量的比较操作

10.重要算法

4.一些误区

总结

C++vector 用法整理 1.头文件 #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; } 2.vector初始化

定义十个整形元素的向量(其中初值不确定)

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); 3.vector对象的重要操作 1.赋值(assign) a.assign(b.begin(),b.begin()+3); //注意!此处,将b 0~2个元素构成的向量赋值给a!与上面不同! a.assign(4,2);// 与vector<int> a(10,1);结果相同 2.返回元素值 //返回最后一个元素 a.back(); //返回第一个元素 a.front(); //数组返回式 a[i]; 3.清空、判断是否为空 a.clear(); a.empty(); 4.删除 //删除最后一个元素 a.pop_back(); //删除一块元素 a.erase(a.begin(),a.begin()+3); 5.插入 //在最后一个向量后插入一个元素 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); } 6.返回vector的现存元素个数、共可容纳个数 a.size(); a.c apacity(); 7.调整元素个数(这个好牛) //将元素个数调整至10,多删少补,补的值随机 a.resize(10); //将元素个数调整至10,多删少补,补的值为2 a.resize(10,2); //大容量扩充(不补充值) a.reserve(100); 8.整体性交换 a.swap(b); 9.向量的比较操作 a==b; //还有 != >= <= > < 10.重要算法 //从小到大排列 sort(a.begin(), a.end()); //倒置但不排列 reverse(a.begin(),a.end()); //元素复制 copy(a.begin(),a.end(),b.begin()); //从某一区块中查找元素值,返回位置 find(a.begin(),a.end(),10); 4.一些误区

下标只能获取已存在的元素,不能进行赋值操作

//错误示例 vector<int> a; for(int i = 0;i<10;i++) a[i] = i; 总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注易知道(ezd.cc)的更多内容!      

推荐阅读