如何在c ++中反向迭代地图

Jac*_*ble 28 c++ loops for-loop

我在使用gcc c ++中的地图上反向迭代时遇到了麻烦.当我使用反向迭代器时,我似乎无法为其分配任何东西 - 编译器抱怨.我正在使用前向迭代器处理一些笨拙的代码,但它不是很优雅.有什么想法吗?

GMa*_*ckG 49

这是一个通过以下方式向后迭代的示例std::map:

#include <iostream>
#include <map>
#include <string>

int main() {
    std::map<std::string, std::string> m;
    m["a"] = "1";
    m["b"] = "2";
    m["c"] = "3";

    for (auto iter = m.rbegin(); iter != m.rend(); ++iter) {
        std::cout << iter->first << ": " << iter->second << std::endl;
    }
}
Run Code Online (Sandbox Code Playgroud)

如果您是C++ 11之前的版本,那么您只需要拼写出来auto,即:

std::map<std::string, std::string>::reverse_iterator
Run Code Online (Sandbox Code Playgroud)

请注意,如果您正在使用boost,则可以使用基于范围的for循环和反向适配器:

#include <boost/range/adaptor/reversed.hpp>

for (auto& iter : boost::adaptors::reverse(m)) {
    std::cout << iter.first << ": " << iter.second << std::endl;
}
Run Code Online (Sandbox Code Playgroud)


hon*_*onk 12

C++20开始,您可以使用Ranges 库std::views::reverse中的范围适配器。如果将其添加到具有结构化绑定的基于范围的 for 循环中,则可以按如下方式向后迭代 an :std::map

#include <map>
#include <ranges>
#include <iostream>

int main() {
    std::map<std::string, int> m = { {"a", 1}, {"b", 2}, {"c", 3} };

    for (auto const& [k, v] : m | std::views::reverse)
        std::cout << k << " => " << v << std::endl;

    return 0;
}
Run Code Online (Sandbox Code Playgroud)

输出:

c => 3
b => 2
a => 1

Wandbox 上的代码