Difference between revisions of "cpp/iterator/make reverse iterator"
From cppreference.com
(+) |
(Wording update.) |
||
(10 intermediate revisions by 8 users not shown) | |||
Line 1: | Line 1: | ||
{{cpp/title|make_reverse_iterator}} | {{cpp/title|make_reverse_iterator}} | ||
{{cpp/iterator/navbar}} | {{cpp/iterator/navbar}} | ||
− | {{ | + | {{ddcla|header=iterator|since=c++14|constexpr=c++17| |
− | + | template< class Iter > | |
− | + | std::reverse_iterator<Iter> make_reverse_iterator( Iter i ); | |
− | template <class | + | |
− | std::reverse_iterator< | + | |
}} | }} | ||
− | |||
− | {{tt|make_reverse_iterator}} is a convenience function template that constructs a {{lc|std::reverse_iterator}} for the given iterator {{ | + | {{tt|make_reverse_iterator}} is a convenience function template that constructs a {{lc|std::reverse_iterator}} for the given iterator {{c|i}} (which must be a {{named req|BidirectionalIterator}}) with the type deduced from the type of the argument. |
===Parameters=== | ===Parameters=== | ||
{{par begin}} | {{par begin}} | ||
− | {{par | i | | + | {{par|i|iterator to be converted to reverse iterator}} |
{{par end}} | {{par end}} | ||
===Return value=== | ===Return value=== | ||
− | + | {{c|std::reverse_iterator<Iter>(i)}} | |
− | === | + | ===Notes=== |
− | {{ | + | {{feature test macro|__cpp_lib_make_reverse_iterator|std=C++14|value=201402L|{{tt|std::make_reverse_iterator}}}} |
− | + | ||
− | + | ===Example=== | |
+ | {{example | ||
+ | |code= | ||
+ | #include <algorithm> | ||
+ | #include <iostream> | ||
+ | #include <iterator> | ||
+ | #include <vector> | ||
+ | |||
+ | int main() | ||
{ | { | ||
− | + | std::vector<int> v{1, 3, 10, 8, 22}; | |
+ | |||
+ | std::sort(v.begin(), v.end()); | ||
+ | std::copy(v.begin(), v.end(), std::ostream_iterator<int>(std::cout, ", ")); | ||
+ | std::cout << '\n'; | ||
+ | |||
+ | std::copy(std::make_reverse_iterator(v.end()), | ||
+ | std::make_reverse_iterator(v.begin()), | ||
+ | std::ostream_iterator<int>(std::cout, ", ")); | ||
+ | std::cout << '\n'; | ||
} | } | ||
+ | |output= | ||
+ | 1, 3, 8, 10, 22, | ||
+ | 22, 10, 8, 3, 1, | ||
}} | }} | ||
− | |||
− | |||
− | |||
===See also=== | ===See also=== | ||
{{dsc begin}} | {{dsc begin}} | ||
− | {{dsc inc | cpp/iterator/dsc reverse_iterator}} | + | {{dsc inc|cpp/iterator/dsc reverse_iterator}} |
− | {{dsc inc | cpp/iterator/dsc rbegin}} | + | {{dsc inc|cpp/iterator/dsc rbegin}} |
− | {{dsc inc | cpp/iterator/dsc rend}} | + | {{dsc inc|cpp/iterator/dsc rend}} |
{{dsc end}} | {{dsc end}} | ||
− | + | {{langlinks|de|es|fr|it|ja|pt|ru|zh}} | |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + |
Latest revision as of 22:33, 4 November 2024
Defined in header <iterator>
|
||
template< class Iter > std::reverse_iterator<Iter> make_reverse_iterator( Iter i ); |
(since C++14) (constexpr since C++17) |
|
make_reverse_iterator
is a convenience function template that constructs a std::reverse_iterator for the given iterator i (which must be a LegacyBidirectionalIterator) with the type deduced from the type of the argument.
Contents |
[edit] Parameters
i | - | iterator to be converted to reverse iterator |
[edit] Return value
std::reverse_iterator<Iter>(i)
[edit] Notes
Feature-test macro | Value | Std | Feature |
---|---|---|---|
__cpp_lib_make_reverse_iterator |
201402L | (C++14) | std::make_reverse_iterator
|
[edit] Example
Run this code
#include <algorithm> #include <iostream> #include <iterator> #include <vector> int main() { std::vector<int> v{1, 3, 10, 8, 22}; std::sort(v.begin(), v.end()); std::copy(v.begin(), v.end(), std::ostream_iterator<int>(std::cout, ", ")); std::cout << '\n'; std::copy(std::make_reverse_iterator(v.end()), std::make_reverse_iterator(v.begin()), std::ostream_iterator<int>(std::cout, ", ")); std::cout << '\n'; }
Output:
1, 3, 8, 10, 22, 22, 10, 8, 3, 1,
[edit] See also
iterator adaptor for reverse-order traversal (class template) | |
(C++14) |
returns a reverse iterator to the beginning of a container or array (function template) |
(C++14) |
returns a reverse end iterator for a container or array (function template) |