std::array::rend, std::array::crend
Материал из cppreference.com
reverse_iterator rend() noexcept; |
(до C++17) | |
constexpr reverse_iterator rend() noexcept; |
(начиная с C++17) | |
const_reverse_iterator rend() const noexcept; |
(до C++17) | |
constexpr const_reverse_iterator rend() const noexcept; |
(начиная с C++17) | |
const_reverse_iterator crend() const noexcept; |
(до C++17) | |
constexpr const_reverse_iterator crend() const noexcept; |
(начиная с C++17) | |
Возвращает обратный итератор на элемент, следующий за последним элементом перевёрнутого array
. Он соответствует элементу, предшествующему первому элементу не перевёрнутого array
. Этот элемент существуют лишь условно, попытка доступа к нему приведёт к неопределенному поведению.
Содержание |
[править] Параметры
(нет)
[править] Возвращаемое значение
Обратный итератор на элемент, следующий за последним элементом.
[править] Сложность
Константная.
[править] Пример
Запустить этот код
#include <algorithm> #include <array> #include <iostream> int main() { std::array<int, 11> a {1, 11, 11, 35, 0, 12, 79, 76, 76, 69, 40}; // Распечатаем элементы массива в обратном порядке, используя const_reverse_iterator объекты std::for_each(a.crbegin(), a.crend(), [](int e){ std::cout << e << ' '; }); // ^^ ^^ std::cout << '\n'; // модифицируем каждый элемент массива, используя неконстантные reverse_iterator объекты std::for_each(a.rbegin(), a.rend(), [](int& e){ e += 32; }); // ^ ^ ^ // распечатаем элементы, как символы, в обратном порядке, используя const_reverse_iterator объекты std::for_each(a.crbegin(), a.crend(), [](char e){ std::cout << e; }); // ^^ ^^ ^^^^ std::cout << '\n'; }
Вывод:
40 69 76 76 79 12 0 35 11 11 1 Hello, C++!
[��равить] See also
(C++11) |
возвращает обратный итератор на начало (public функция-элемент) |