标签:cin main 方法 ace href tis 打印 UNC 函数
时间:2014.04.20
地点:基地二楼
----------------------------------------------------------------------------
#include<iostream>
#include<iterator>
#include<vector>
#include<algorithm>
using namespace std;
int main()
{
vector<int> my_vec;
copy(istream_iterator<int>(cin), istream_iterator<int>(),
back_inserter(my_vec));
}
这段代码用于从cin流中读取int类型数据,并使用copy算法将数据填空到一个vector容器中,目标迭代器是一个与my_vec绑定的插入迭代器。
这里并没有什么问题:
auto first = find(my_vec.begin(), my_vec.end(), 2);
auto last = find(my_vec.begin(), my_vec.end(), 10);
*first = 3;
我们知道find()算法的工作流程就是假设在迭代器指定的范围内没有找到目标值,将返回终止迭代器,这个迭代器指向容器中最后一个元素的下一个位置,并非一个真正有效的迭代器。
copy(first, last, ostream_iterator<int>(cout, "\n"));
代码本身是想使用迭代器对构成范围[first,last),但有可能first还在last之后,那么这种范围也是不同意的。也就是说first必须位于fast所指向的对象之前才干够构成一个有效范围。
my_vec.insert(--my_vec.end(),2);
在标准库的实现中,对迭代器的实现是使用类型的指针来表示vector<T>::iterator的。C++中并不同意对内置类型的暂时变量进行改动,比方:Type* function(); //定义了一个返回Type* 的函数
p=--function(); //function返回Type* 是一个暂时变量,这里先对暂时变量进行了改动然后赋给p是非法的
合理的方式是:my_vec.insert(my_vec.end()-1,2);
my_vec.push_back(1);
my_vec.push_back(1);
my_vec.push_back(1);
my_vec.push_back(1);
my_vec.push_back(1);
my_vec.push_back(1);
my_vec.push_back(1);
my_vec.push_back(1);
my_vec.push_back(1);
my_vec.push_back(1);
my_vec.push_back(1);
copy(first, last, ostream_iterator<int>(cout, "\n"));
当对容器进行插入操作后。先前获得的迭代器已经无效
比方: --my_vec.end() ? (在底层表现为对函数返回的一个指针的递减操作)
标签:cin main 方法 ace href tis 打印 UNC 函数
原文地址:https://www.cnblogs.com/mqxnongmin/p/10476212.html