C++ vector的用法
vector 是向量类型,它可以容纳许多类型的数据,如若干个整数,所以称其为容器。vector没有find()函数, 且返回的是迭代器, 不是数值, vector 是C++ STL的一个重要成员,使用它时需要包含头文件:
1 |
1. vector 的初始化:可以有五种方式,举例说明如下:
1 | (1) vector<int> a(10); //定义了10个整型元素的向量(尖括号中为元素类型名,它可以是任何合法的数据类型),但没有给出初值,其值是不确定的。 |
2. vector对象的几个重要操作,举例说明如下:
1 | (1)a.assign(b.begin(), b.begin()+3); //b为向量,将b的0~2个元素构成的向量赋给a |
3. 顺序访问vector的几种方式,举例说明如下:
3.1 向向量a中添加元素
-
向向量a中逐个添加
1
2
3vector<int> a;
for(int i=0;i<10;i++)
a.push_back(i); -
也可以从数组中选择元素向向量中添加
1
2
3
4int a[6]={1,2,3,4,5,6};
vector<int> b;
for(int i=1;i<=4;i++)
b.push_back(a[i]); -
也可以从现有向量中选择元素向向量中添加
1
2
3
4
5int a[6]={1,2,3,4,5,6};
vector<int> b;
vector<int> c(a,a+4);
for(vector<int>::iterator it=c.begin();it<c.end();it++)
b.push_back(*it); -
也可以从文件中读取元素向向量中添加
1
2
3
4ifstream in("data.txt");
vector<int> a;
for(int i; in>>i)
a.push_back(i); -
误区
1
2
3vector<int> a;
for(int i=0;i<10;i++)
a[i]=i;这种做法以及类似的做法都是错误的。下标只能用于获取已存在的元素,而现在的a[i]还是空的对象
3.2 向向量中读取元素
-
通过下标方式读取
1
2
3
4int a[6]={1,2,3,4,5,6};
vector<int> b(a,a+4);
for(int i=0;i<=b.size()-1;i++)
cout<<b[i]<<" "; -
通过遍历器方式读取
1 | int a[6]={1,2,3,4,5,6}; |
4. 几种重要的算法,使用时需要包含头文件:
1 |
|
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 Malloy Yuan 的个人博客!
评论