练习9.21
如果我们将第308页中使用 insert 返回值将元素添加到list中的循环程序改写为将元素插入到vector中,分析循环将如何工作。
一样的。如书上所说:
第一次调用
insert
会将我们刚刚读入的string
插入到iter
所指向的元素之前的位置。insert
返回的迭代器恰好指向这个新元素。我们将此迭代器赋予iter
并重复循环,读取下一个单词。只要继续有单词读入,每步 while 循环就会将一个新元素插入到iter
之前,并将iter
改变为新加入元素的尾置。此元素为(新的)首元素。因此,每步循环将一个元素插入到list
首元素之前的位置。
练习9.22
假定iv是一个int的vector,下面的程序存在什么错误?你将如何修改?
vector<int>::iterator iter = iv.begin(),
mid = iv.begin() + iv.size() / 2;
while (iter != mid)
if (*iter == some_val)
iv.insert(iter