std::deque<T,Allocator>::rend, std::deque<T,Allocator>::crend
From cppreference.com
reverse_iterator rend();
|
(1) | (noexcept since C++11) |
const_reverse_iterator rend() const;
|
(2) | (noexcept since C++11) |
const_reverse_iterator crend() const noexcept;
|
(3) | (since C++11) |
Returns a reverse iterator to the element following the last element of the reversed deque. It corresponds to the element preceding the first element of the non-reversed deque. This element acts as a placeholder, attempting to access it results in undefined behavior.
Return value
Reverse iterator to the element following the last element.
Complexity
Constant.
Notes
libc++ backports crend() to C++98 mode.
Example
Run this code
#include <algorithm>
#include <cassert>
#include <iostream>
#include <numeric>
#include <string>
#include <deque>
int main()
{
std::deque<int> nums{1, 2, 4, 8, 16};
std::deque<std::string> fruits{"orange", "apple", "raspberry"};
std::deque<char> empty;
// Print deque nums.
std::for_each(nums.crbegin(), nums.crend(),
[](const int n) { std::cout << n << ' '; });
std::cout << '\n';
// Sum all integers in the deque nums, printing only the result.
std::cout << "Sum of nums: "
<< std::accumulate(nums.crbegin(), nums.crend(), 0) << '\n';
// Print the last fruit in the deque fruits, checking if there is any.
if (!fruits.empty())
std::cout << "Last fruit: " << *fruits.crbegin() << '\n';
if (empty.crbegin() == empty.crend())
std::cout << "deque ‘empty’ is indeed empty.\n";
// Modify the last element in nums.
*nums.rbegin() = 32;
assert(*nums.crbegin() == 32);
}
Output:
16 8 4 2 1
Sum of nums: 31
Last fruit: raspberry
deque ‘empty’ is indeed empty.
See also
(C++11) |
returns a reverse iterator to the beginning (public member function) |
(C++14) |
returns a reverse end iterator for a container or array (function template) |