Vector简介:
Vector是一个类模板,而不是一种数据类型,使用时需要:
--------------------------------------------------------------
#include<vector>
using std::vector;
--------------------------------------------------------------
Vector对象的定义和初始化:
--->定义vector:
vector<类型> 变量名;
--->初始化:
vector<T> v1: vector保存类型为T的对象,默认构造函数v1为空。
vector<T> v2(v1):v2是v1的一个副本
vector<T> v3(n, i):v3包含n个值为i的元素
vector<T> v4(n):v4含有值初始化的元素的n个副本,具体初始值由系统定义。
Vector对象的操作:
v.empty():如果v是空,返回true,否则返回false。
v.size():返回v中元素的个数。
v.push_back(t):在v的末尾增加一个值为t的元素
v[n]:返回v中位置为n的元素,下标从0开始。
v1 = v2:将v2赋给v1;
保持逻辑操作符的原有含义
Note:在C++中的for循环判断中,习惯用!=而不是><来编写循环的判断条件,只是为了安全的泛型编程。
Vector迭代器的简介:
vector对象元素的访问除了使用下标的方法以外,常用的方法是使用迭代器,迭代器是一种检查容器中元素并遍历元素的数据类型,标准库为每一种容器定义了一种迭代器类型。
容器的iterator类型分类:
1. vector<T>::iterator iter;
2. vector<T>::const_iterator iter;
容器的iterator的其他操作:
迭代器还可以用来进行比较运算和算术运算。
容器的iterator使用:
1. vector<T>::iterator iter;
概述:迭代器相当于指向vector容器的指针。
for(vector<int>::iterator iter = ivec.begin(); iter!=ivec.end();++iter)
{
*iter = 0;
}
迭代器最为常用的操作就是用已经存在的vector向量的begin和end对其进行赋值。
2.vector<T>::const_iterator iter;
它与上面的区别是使用它所定义的iter只能读取容器内的元素,不能改变它的值。要注意的是可以使用++iter,他与const vector不同,若定义const vector<T>::iterator iter,则iter不能进行自加运算。
Vector元素删除:
在使用Vector的时候,不可避免的要对其中的一些元素进行删除操作,删除的时候使用的操作时vector.erase(迭代器)的结构,具体的例子如下所示:
#include <vector>
#include <iostream>
using namespace std;
void main()
{
vector<int> a;
for ( int i = 0; i != 5; i++ )
{
a.push_back(i+1);
cout<<"the value is "<<a[i]<<endl;
}
cout<<a.size()<<endl;
cout<<endl;
for ( vector<int>::iterator iter = a.begin(); iter != a.end(); iter++ )
{
if ( *iter == 3 )
{
iter = a.erase(iter);
/*此处一定要注意:在使用erase后,iter编程了一个野指针,但是erase返回的值指向当前被删元素的前一个元素,因此要返回迭代器的指针,
这样循环过程会顺利进行*/
}
cout<<"the value is "<<*iter<<endl;
}
cout<<a.size();
}