练习10.34:使用reverse_iterator逆序打印一个vector
练习10.35:使用普通迭代器逆序打印一个vector。
练习10.36:使用find在一个int的list中查找最后一个值为0的元素。
练习10.37:给定一个包含10个元素的vector,将位置3,7之间的元素按逆序拷贝到一个list中。
答: 见练习10.34.cpp – 练习10.37.cpp
练习10.34
/*
*练习10.34
*2015/9/10
*问题描述:练习10.34:使用reverse_iterator逆序打印一个vector
*作者:Nick Feng
*邮箱:nickgreen23@163.com
*/
#include <iostream>
#include <algorithm>
#include <vector>
#include <iterator>
using namespace std;
int main()
{
vector<int> vec = {1,2,3,4,5,6,7,8,9,10};
ostream_iterator<int> out_iter(cout," ");//打印正序
copy(vec.cbegin(),vec.cend(),out_iter);
cout << endl;
copy(vec.crbegin(),vec.crend(),out_iter);//打印逆序
cout << endl;
return 0;
}
练习10.35
/*
*练习10.35
*2015/9/10
*问题描述:练习10.35:使用普通迭代器逆序打印一个vector。
*作者:Nick Feng
*邮箱:nickgreen23@163.com
*/
#include <iostream>
#include <vector>
#include <algorithm>
#include <iterator>
using namespace std;
int main()
{
vector<int> vec = {1,2,3,4,5,6,7,8,9,10};
ostream_iterator<int> out_iter(cout," ");
copy(vec.begin(),vec.end(),out_iter);
cout << endl;
for(auto it = vec.end()-1; it != vec.begin() -1; --it)
//vec.end()在最后一个元素后一位
cout << *it << " ";
cout << endl;
return 0;
}
练习10.36
/*
*练习10.36
*2015/9/10
*问题描述:练习10.36:使用find在一个int的list中查找最后一个值为0的元素。。
*作者:Nick Feng
*邮箱:nickgreen23@163.com
*/
#include <iostream>
#include <algorithm>
#include <list>
#include <iterator>
using namespace std;
int main()
{
list<int> li = {1,0,3,4,5,6,7,8,0,9};
ostream_iterator<int> out_iter(cout," ");
copy(li.begin(),li.end(),out_iter); //打印序列
cout << endl;
list<int>::reverse_iterator wc = find(li.rbegin(),li.rend(),0);
cout << *wc << endl;
//这里看不出来是否是最后一个0,验证前后是否为8,9
copy(li.rbegin(),wc,out_iter);
//打印为9看是否正确
cout << endl;
return 0;
}
练习10.37
/*
*练习10.37
*2015/9/10
*问题描述:练习10.37:给定一个包含10个元素的vector,将位置3,7之间的元素按逆序拷贝到一个list中。
*作者:Nick Feng
*邮箱:nickgreen23@163.com
*/
#include <iostream>
#include <vector>
#include <algorithm>
#include <iterator>
#include <list>
using namespace std;
int main()
{
vector<int> vec = {1,2,3,4,5,6,7,8,9,10};
ostream_iterator<int> out_iter(cout," ");
copy(vec.begin(),vec.end(),out_iter);
//正序打印 1 2 3 4 5 6 7 8 9
cout << endl;
list<int> li(vec.rbegin()+3,vec.rend()-3);
//拷贝后三到前三中间元素
copy(li.begin(),li.end(),out_iter);
//打印出 7 6 5 4
cout << endl;
return 0;
}