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个迭代器的距离