 
- C++ Library - Home
- C++ Library - <fstream>
- C++ Library - <iomanip>
- C++ Library - <ios>
- C++ Library - <iosfwd>
- C++ Library - <iostream>
- C++ Library - <istream>
- C++ Library - <ostream>
- C++ Library - <sstream>
- C++ Library - <streambuf>
- C++ Library - <atomic>
- C++ Library - <complex>
- C++ Library - <exception>
- C++ Library - <functional>
- C++ Library - <limits>
- C++ Library - <locale>
- C++ Library - <memory>
- C++ Library - <new>
- C++ Library - <numeric>
- C++ Library - <regex>
- C++ Library - <stdexcept>
- C++ Library - <string>
- C++ Library - <thread>
- C++ Library - <tuple>
- C++ Library - <typeinfo>
- C++ Library - <utility>
- C++ Library - <valarray>
- The C++ STL Library
- C++ Library - <array>
- C++ Library - <bitset>
- C++ Library - <deque>
- C++ Library - <forward_list>
- C++ Library - <list>
- C++ Library - <map>
- C++ Library - <multimap>
- C++ Library - <queue>
- C++ Library - <priority_queue>
- C++ Library - <set>
- C++ Library - <stack>
- C++ Library - <unordered_map>
- C++ Library - <unordered_set>
- C++ Library - <vector>
- C++ Library - <algorithm>
- C++ Library - <iterator>
- The C++ Advanced Library
- C++ Library - <any>
- C++ Library - <barrier>
- C++ Library - <bit>
- C++ Library - <chrono>
- C++ Library - <cinttypes>
- C++ Library - <clocale>
- C++ Library - <condition_variable>
- C++ Library - <coroutine>
- C++ Library - <cstdlib>
- C++ Library - <cstring>
- C++ Library - <cuchar>
- C++ Library - <charconv>
- C++ Library - <cfenv>
- C++ Library - <cmath>
- C++ Library - <ccomplex>
- C++ Library - <expected>
- C++ Library - <format>
- C++ Library - <future>
- C++ Library - <flat_set>
- C++ Library - <flat_map>
- C++ Library - <filesystem>
- C++ Library - <generator>
- C++ Library - <initializer_list>
- C++ Library - <latch>
- C++ Library - <memory_resource>
- C++ Library - <mutex>
- C++ Library - <mdspan>
- C++ Library - <optional>
- C++ Library - <print>
- C++ Library - <ratio>
- C++ Library - <scoped_allocator>
- C++ Library - <semaphore>
- C++ Library - <source_location>
- C++ Library - <span>
- C++ Library - <spanstream>
- C++ Library - <stacktrace>
- C++ Library - <stop_token>
- C++ Library - <syncstream>
- C++ Library - <system_error>
- C++ Library - <string_view>
- C++ Library - <stdatomic>
- C++ Library - <variant>
- C++ STL Library Cheat Sheet
- C++ STL - Cheat Sheet
- C++ Programming Resources
- C++ Programming Tutorial
- C++ Useful Resources
- C++ Discussion
C++ multimap::rend() Function
The C++ std::multimap::rend() function is used to return a reverse iterator pointing to the element preceding the first element of the multimap. It is used in reverse traversal of the multimap, starting from the last element to the first. The rend() iterator is a position before the beginning, enabling safe reverse iteration. This function does not modify the multimap, it only provides a means to navigate through it in reverse order. The time complexity of this function is constant i.e. O(1).
Syntax
Following is the syntax for std::multimap::rend() function.
reverse_iterator rend() nothrow; const_reverse_iterator rend() const nothrow;
Parameters
It does not accept any parameters.
Return value
This function returns a reverse iterator to the reverse end of the container.
Example
Let's look at the following example, where we are going to demonstrate the basic usage of rend() function.
#include <iostream>
#include <map>
int main()
{
    std::multimap<int, std::string> a = {{1, "Vanakam"}, {3, "Hi"}, {2, "Hello"}};
    for (auto x = a.rbegin(); x != a.rend(); ++x) {
        std::cout << x->first << ": " << x->second << std::endl;
    }
    return 0;
}
Output
Following is the output of the above code −
3: Hi 2: Hello 1: Vanakam
Example
Consider the following example, where we are going to check if the multimap is empty by comparing rend() with rbegin().
#include <iostream>
#include <map>
int main()
{
    std::multimap<int, std::string> a;
    if (a.rend() == a.rbegin()) {
        std::cout << "Multimap Is Empty." << std::endl;
    } else {
        std::cout << "Multimap Is Not Empty." << std::endl;
    }
    return 0;
}
Output
Output of the above code is as follows −
Multimap Is Empty.
Example
In the following example, we are going to find the elements with key and iterate over the multimap in reverse order, strating from the end of the found range.
#include <iostream>
#include <map>
int main()
{
    std::multimap<int, std::string> a = {{3, "BMW"}, {1, "Cruze"}, {2, "City"}, {1, "Sail"}};
    auto b = a.equal_range(2);
    for (auto x = std::make_reverse_iterator(b.second); x != a.rend(); ++x) {
        std::cout << x->first << " --> " << x->second << std::endl;
    }
    return 0;
}
Output
If we run the above code it will generate the following output −
2 --> City 1 --> Sail 1 --> Cruze