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个迭代器的距离
本文探讨了C++中使用迭代器进行算法操作的方法,重点解释了如何正确地使用迭代器来计算中间元素,并指出了使用错误方法可能导致的编译错误。
14

被折叠的 条评论
为什么被折叠?



