C++ Primer第四版 P88

如果采用下面的计算方法来计算mid会产生什么结果?

正确方法:


//用迭代器算术操作,初始化mid,使其指向vi中最靠近正中间的元素
vector<int>::iterator mid=vi.begin()+vi.size()/2;


错误方法:


//如采用下面的方法来计算mid
vector<int>::iterator mid=(vi.begin()+vi.end())/2
//将两个迭代器相加的操作是未定义的,因此用这种方法计算mid会出现编译错误


vi.begin()与vi.end()返回的是迭代器。vi.size()返回的是元素个数。

迭代器的算法操作:


iter + n     //产生一个新的迭代器   
iter - n //产生一个新的迭代器
iter1 - iter2 //计算2个迭代器的距离