forked from Mooophy/Cpp-Primer
-
Notifications
You must be signed in to change notification settings - Fork 1
/
ex10_34_35_36_37.cpp
56 lines (50 loc) · 1.58 KB
/
ex10_34_35_36_37.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
// @Alan @pezy
//
// Exercise 10.34:
// Use reverse_iterators to print a vector in reverse order.
//
// Exercise 10.35:
// Now print the elements in reverse order using ordinary iterators.
//
// Exercise 10.36:
// Use find to find the last element in a list of ints with value 0.
//
// Exercise 10.37:
// Given a vector that has ten elements, copy the elements from positions
// 3 through 7 in reverse order to a list.
//
#include <iostream>
#include <algorithm>
#include <list>
#include <vector>
#include <iterator>
int main()
{
std::vector<int> vec = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 };
// 10.34
for (auto rit = vec.crbegin(); rit != vec.crend(); ++rit)
std::cout << *rit << " ";
std::cout << std::endl;
// 10.35
for (auto it = std::prev(vec.cend()); true; --it) {
std::cout << *it << " ";
if (it == vec.cbegin()) break;
}
std::cout << std::endl;
// 10.36
std::list<int> lst = { 1, 2, 3, 4, 0, 5, 6 };
auto found_0 = std::find(lst.crbegin(), lst.crend(), 0);
std::cout << std::distance(found_0, lst.crend()) << std::endl;
// 10.37
std::list<int> ret_lst(8 - 3);
std::copy(vec.cbegin() + 3, vec.cbegin() + 8, ret_lst.rbegin());
// 0, 1, 2, 3, 4, 5, 6, 7, 8, 9
// ^ ^
// rend rbegin
// @note: std::copy copies the range [first, last) into result.
// hence, the arguments here denote:
// [7 6 5 4 3 2)
// ^ this one is specified but not included.
for (auto i : ret_lst) std::cout << i << " ";
std::cout << std::endl;
}