std::list<T,Allocator>:: rbegin, std::list<T,Allocator>:: crbegin
|
reverse_iterator rbegin
(
)
;
|
(1) |
(C++11以降 noexcept)
(C++26以降 constexpr) |
|
const_reverse_iterator rbegin
(
)
const
;
|
(2) |
(C++11以降 noexcept)
(C++26以降 constexpr) |
|
const_reverse_iterator crbegin
(
)
const
noexcept
;
|
(3) |
(C++11以降)
(C++26以降 constexpr) |
反転された * this の最初の要素を指す逆方向イテレータを返します。これは非反転 * this の最後の要素に対応します。
* this が空の場合、返されるイテレータは rend() と等しくなります。
目次 |
戻り値
最初の要素への逆方向イテレータ。
計算量
定数。
注記
返される逆イテレータの 基盤となるイテレータ は endイテレータ です。したがって、endイテレータが無効化された場合、返されるイテレータも無効化されます。
libc++は
crbegin()
をC++98モードにバックポートします。
例
#include <algorithm> #include <iostream> #include <numeric> #include <string> #include <list> int main() { std::list<int> nums{1, 2, 4, 8, 16}; std::list<std::string> fruits{"orange", "apple", "raspberry"}; std::list<char> empty; // リストを表示 std::for_each(nums.rbegin(), nums.rend(), [](const int n) { std::cout << n << ' '; }); std::cout << '\n'; // リストnums内の全ての整数を合計し(存在する場合)、結果のみを表示 std::cout << "Sum of nums: " << std::accumulate(nums.rbegin(), nums.rend(), 0) << '\n'; // リストfruitsの最初のフルーツを表示(存在するか確認) if (!fruits.empty()) std::cout << "First fruit: " << *fruits.rbegin() << '\n'; if (empty.rbegin() == empty.rend()) std::cout << "list 'empty' is indeed empty.\n"; }
出力:
16 8 4 2 1 Sum of nums: 31 First fruit: raspberry list 'empty' is indeed empty.
関連項目
|
(C++11)
|
末尾を指す逆イテレータを返す
(public member function) |
|
(C++14)
|
コンテナまたは配列の先頭を指す逆イテレータを返す
(function template) |