Scroll to navigation

std::multiset::rbegin,(3) C++ Standard Libary std::multiset::rbegin,(3)

NAME

std::multiset::rbegin, - std::multiset::rbegin,

Synopsis


reverse_iterator rbegin(); (1) (noexcept since C++11)
const_reverse_iterator rbegin() const; (2) (noexcept since C++11)
const_reverse_iterator crbegin() const noexcept; (3) (since C++11)


Returns a reverse iterator to the first element of the reversed multiset. It
corresponds to the last element of the non-reversed multiset. If the multiset is
empty, the returned iterator is equal to rend().


range-rbegin-rend.svg

Parameters


(none)

Return value


Reverse iterator to the first element.

Complexity


Constant.

Notes


Because both iterator and const_iterator are constant iterators (and may in fact be
the same type), it is not possible to mutate the elements of the container through
an iterator returned by any of these member functions.


The underlying iterator of the returned reverse iterator is the end iterator. Hence
the returned iterator is invalidated if and when the end iterator is invalidated.


libc++ backports crbegin() to C++98 mode.

Example

// Run this code


#include <iostream>
#include <set>


int main()
{
std::multiset<unsigned> rep{1, 2, 3, 4, 1, 2, 3, 4};


for (auto it = rep.crbegin(); it != rep.crend(); ++it)
{
for (auto n = *it; n > 0; --n)
std::cout << "⏼" << ' ';
std::cout << '\n';
}
}

Output:


⏼ ⏼ ⏼ ⏼
⏼ ⏼ ⏼ ⏼
⏼ ⏼ ⏼
⏼ ⏼ ⏼
⏼ ⏼
⏼ ⏼

See also


rend returns a reverse iterator to the end
crend (public member function)
(C++11)
rbegin returns a reverse iterator to the beginning of a container or array
crbegin (function template)
(C++14)

2024.06.10 http://cppreference.com